2010-06-09 16:13:47 +02:00
|
|
|
/**************************************************************************
|
|
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
|
|
|
|
** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
|
|
|
|
|
**
|
|
|
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
|
|
|
|
**
|
|
|
|
|
** Commercial Usage
|
|
|
|
|
**
|
|
|
|
|
** Licensees holding valid Qt Commercial licenses may use this file in
|
|
|
|
|
** accordance with the Qt Commercial License Agreement provided with the
|
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
|
|
|
** a written agreement between you and Nokia.
|
|
|
|
|
**
|
|
|
|
|
** GNU Lesser General Public License Usage
|
|
|
|
|
**
|
|
|
|
|
** 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.
|
|
|
|
|
**
|
|
|
|
|
** If you are unsure which license is appropriate for your use, please
|
|
|
|
|
** contact the sales department at http://qt.nokia.com/contact.
|
|
|
|
|
**
|
|
|
|
|
**************************************************************************/
|
|
|
|
|
|
|
|
|
|
#include "qmlengine.h"
|
|
|
|
|
|
|
|
|
|
#include "debuggerstringutils.h"
|
|
|
|
|
#include "debuggerdialogs.h"
|
|
|
|
|
#include "breakhandler.h"
|
|
|
|
|
#include "debuggerconstants.h"
|
|
|
|
|
#include "debuggermanager.h"
|
|
|
|
|
#include "moduleshandler.h"
|
|
|
|
|
#include "registerhandler.h"
|
|
|
|
|
#include "stackhandler.h"
|
|
|
|
|
#include "watchhandler.h"
|
|
|
|
|
#include "watchutils.h"
|
|
|
|
|
#include "moduleshandler.h"
|
|
|
|
|
|
|
|
|
|
#include <utils/qtcassert.h>
|
|
|
|
|
|
|
|
|
|
#include <QtCore/QDateTime>
|
|
|
|
|
#include <QtCore/QDebug>
|
|
|
|
|
#include <QtCore/QDir>
|
|
|
|
|
#include <QtCore/QFileInfo>
|
|
|
|
|
#include <QtCore/QTimer>
|
|
|
|
|
|
|
|
|
|
#include <QtGui/QAction>
|
|
|
|
|
#include <QtGui/QApplication>
|
|
|
|
|
#include <QtGui/QMainWindow>
|
|
|
|
|
#include <QtGui/QMessageBox>
|
|
|
|
|
#include <QtGui/QToolTip>
|
|
|
|
|
|
|
|
|
|
#include <QtNetwork/QTcpSocket>
|
|
|
|
|
|
|
|
|
|
#define DEBUG_QML 1
|
|
|
|
|
#if DEBUG_QML
|
|
|
|
|
# define SDEBUG(s) qDebug() << s
|
|
|
|
|
#else
|
|
|
|
|
# define SDEBUG(s)
|
|
|
|
|
#endif
|
|
|
|
|
# define XSDEBUG(s) qDebug() << s
|
|
|
|
|
|
|
|
|
|
#define CB(callback) &QmlEngine::callback, STRINGIFY(callback)
|
|
|
|
|
|
|
|
|
|
//#define USE_CONGESTION_CONTROL
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace Debugger {
|
|
|
|
|
namespace Internal {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class QmlResponse
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
QmlResponse() {}
|
|
|
|
|
QmlResponse(const QByteArray &data_) : data(data_) {}
|
|
|
|
|
|
|
|
|
|
QString toString() const { return data; }
|
|
|
|
|
|
|
|
|
|
QByteArray data;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
|
|
|
|
// QmlCommand
|
|
|
|
|
//
|
|
|
|
|
///////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
QString QmlEngine::QmlCommand::toString() const
|
|
|
|
|
{
|
|
|
|
|
return quoteUnprintableLatin1(command);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
|
|
|
|
// QmlEngine
|
|
|
|
|
//
|
|
|
|
|
///////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
QmlEngine::QmlEngine(DebuggerManager *manager)
|
|
|
|
|
: IDebuggerEngine(manager)
|
|
|
|
|
{
|
|
|
|
|
m_congestion = 0;
|
|
|
|
|
m_inAir = 0;
|
|
|
|
|
|
|
|
|
|
m_sendTimer.setSingleShot(true);
|
|
|
|
|
m_sendTimer.setInterval(100); // ms
|
|
|
|
|
connect(&m_sendTimer, SIGNAL(timeout()), this, SLOT(handleSendTimer()));
|
|
|
|
|
|
|
|
|
|
m_socket = new QTcpSocket(this);
|
|
|
|
|
connect(m_socket, SIGNAL(connected()), this, SLOT(socketConnected()));
|
|
|
|
|
connect(m_socket, SIGNAL(disconnected()), this, SLOT(socketDisconnected()));
|
|
|
|
|
connect(m_socket, SIGNAL(error(QAbstractSocket::SocketError)),
|
|
|
|
|
this, SLOT(socketError(QAbstractSocket::SocketError)));
|
|
|
|
|
|
|
|
|
|
//void aboutToClose ()
|
|
|
|
|
//void bytesWritten ( qint64 bytes )
|
|
|
|
|
//void readChannelFinished ()
|
|
|
|
|
connect(m_socket, SIGNAL(readyRead()), this, SLOT(socketReadyRead()));
|
|
|
|
|
|
|
|
|
|
//connect(m_socket, SIGNAL(hostFound())
|
|
|
|
|
//connect(m_socket, SIGNAL(proxyAuthenticationRequired(QNetworkProxy, QAuthenticator *)))
|
|
|
|
|
//connect(m_socket, SIGNAL(stateChanged(QAbstractSocket::SocketState)),
|
|
|
|
|
// thism SLOT(socketStateChanged(QAbstractSocket::SocketState)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QmlEngine::~QmlEngine()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::socketReadyRead()
|
|
|
|
|
{
|
|
|
|
|
//XSDEBUG("QmlEngine::socketReadyRead()");
|
|
|
|
|
m_inbuffer.append(m_socket->readAll());
|
|
|
|
|
int pos = 0;
|
|
|
|
|
while (1) {
|
|
|
|
|
// the "\3" is followed by either "\1" or "\2"
|
|
|
|
|
int next = m_inbuffer.indexOf("\3", pos);
|
|
|
|
|
//qDebug() << "pos: " << pos << "next: " << next;
|
|
|
|
|
if (next == -1)
|
|
|
|
|
break;
|
|
|
|
|
handleResponse(m_inbuffer.mid(pos, next - pos));
|
|
|
|
|
pos = next + 2;
|
|
|
|
|
}
|
|
|
|
|
m_inbuffer.clear();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::socketConnected()
|
|
|
|
|
{
|
|
|
|
|
showStatusMessage("Socket connected.");
|
|
|
|
|
m_socket->waitForConnected(2000);
|
|
|
|
|
//sendCommand("Locator", "redirect", "ID");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::socketDisconnected()
|
|
|
|
|
{
|
|
|
|
|
XSDEBUG("FIXME: QmlEngine::socketDisconnected()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::socketError(QAbstractSocket::SocketError)
|
|
|
|
|
{
|
|
|
|
|
QString msg = tr("%1.").arg(m_socket->errorString());
|
|
|
|
|
//QMessageBox::critical(q->mainWindow(), tr("Error"), msg);
|
|
|
|
|
showStatusMessage(msg);
|
|
|
|
|
manager()->notifyInferiorExited();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeDebuggerCommand(const QString &command)
|
|
|
|
|
{
|
|
|
|
|
QByteArray cmd = command.toUtf8();
|
|
|
|
|
cmd = cmd.mid(cmd.indexOf(' ') + 1);
|
|
|
|
|
QByteArray null;
|
|
|
|
|
null.append('\0');
|
|
|
|
|
// FIXME: works for single-digit escapes only
|
|
|
|
|
cmd.replace("\\0", null);
|
|
|
|
|
cmd.replace("\\1", "\1");
|
|
|
|
|
cmd.replace("\\3", "\3");
|
|
|
|
|
QmlCommand tcf;
|
|
|
|
|
tcf.command = cmd;
|
|
|
|
|
enqueueCommand(tcf);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::shutdown()
|
|
|
|
|
{
|
|
|
|
|
m_congestion = 0;
|
|
|
|
|
m_inAir = 0;
|
|
|
|
|
m_services.clear();
|
|
|
|
|
exitDebugger();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::exitDebugger()
|
|
|
|
|
{
|
|
|
|
|
SDEBUG("QmlEngine::exitDebugger()");
|
|
|
|
|
manager()->notifyInferiorExited();
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-14 13:17:54 +02:00
|
|
|
void QmlEngine::startDebugger()
|
2010-06-09 16:13:47 +02:00
|
|
|
{
|
2010-06-14 13:17:54 +02:00
|
|
|
QTC_ASSERT(runControl(), return);
|
2010-06-09 16:13:47 +02:00
|
|
|
qDebug() << "STARTING QML ENGINE";
|
|
|
|
|
setState(InferiorRunningRequested);
|
|
|
|
|
showStatusMessage(tr("Running requested..."), 5000);
|
2010-06-14 13:17:54 +02:00
|
|
|
const DebuggerStartParameters &sp = runControl()->sp();
|
|
|
|
|
const int pos = sp.remoteChannel.indexOf(QLatin1Char(':'));
|
|
|
|
|
const QString host = sp.remoteChannel.left(pos);
|
|
|
|
|
const quint16 port = sp.remoteChannel.mid(pos + 1).toInt();
|
2010-06-09 16:13:47 +02:00
|
|
|
//QTimer::singleShot(0, this, SLOT(runInferior()));
|
|
|
|
|
m_socket->connectToHost(host, port);
|
|
|
|
|
emit startSuccessful();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::continueInferior()
|
|
|
|
|
{
|
|
|
|
|
SDEBUG("QmlEngine::continueInferior()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::runInferior()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::interruptInferior()
|
|
|
|
|
{
|
|
|
|
|
XSDEBUG("QmlEngine::interruptInferior()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeStep()
|
|
|
|
|
{
|
|
|
|
|
//SDEBUG("QmlEngine::executeStep()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeStepI()
|
|
|
|
|
{
|
|
|
|
|
//SDEBUG("QmlEngine::executeStepI()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeStepOut()
|
|
|
|
|
{
|
|
|
|
|
//SDEBUG("QmlEngine::executeStepOut()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeNext()
|
|
|
|
|
{
|
|
|
|
|
//SDEBUG("QmlEngine::nextExec()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeNextI()
|
|
|
|
|
{
|
|
|
|
|
//SDEBUG("QmlEngine::executeNextI()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeRunToLine(const QString &fileName, int lineNumber)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(fileName)
|
|
|
|
|
Q_UNUSED(lineNumber)
|
|
|
|
|
SDEBUG("FIXME: QmlEngine::executeRunToLine()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeRunToFunction(const QString &functionName)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(functionName)
|
|
|
|
|
XSDEBUG("FIXME: QmlEngine::executeRunToFunction()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::executeJumpToLine(const QString &fileName, int lineNumber)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(fileName)
|
|
|
|
|
Q_UNUSED(lineNumber)
|
|
|
|
|
XSDEBUG("FIXME: QmlEngine::executeJumpToLine()");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::activateFrame(int index)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(index)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::selectThread(int index)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(index)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::attemptBreakpointSynchronization()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::loadSymbols(const QString &moduleName)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(moduleName)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::loadAllSymbols()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::reloadModules()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::requestModuleSymbols(const QString &moduleName)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(moduleName)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void QmlEngine::handleResponse(const QByteArray &response)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(response);
|
|
|
|
|
/*
|
|
|
|
|
static QTime lastTime;
|
|
|
|
|
|
2010-06-14 18:19:02 +02:00
|
|
|
//showMessage(_(" "), currentTime(), LogTime);
|
2010-06-09 16:13:47 +02:00
|
|
|
QList<QByteArray> parts = response.split('\0');
|
|
|
|
|
if (parts.size() < 2 || !parts.last().isEmpty()) {
|
|
|
|
|
SDEBUG("WRONG RESPONSE PACKET LAYOUT" << parts);
|
|
|
|
|
//if (response.isEmpty())
|
|
|
|
|
acknowledgeResult();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
parts.removeLast(); // always empty
|
|
|
|
|
QByteArray tag = parts.at(0);
|
|
|
|
|
int n = parts.size();
|
|
|
|
|
if (n == 2 && tag == "N") { // unidentified command
|
|
|
|
|
int token = parts.at(1).toInt();
|
|
|
|
|
QmlCommand tcf = m_cookieForToken[token];
|
|
|
|
|
SDEBUG("COMMAND NOT RECOGNIZED FOR TOKEN" << token << tcf.toString());
|
|
|
|
|
showDebuggerOutput(LogOutput, QString::number(token) + "^"
|
|
|
|
|
+ "NOT RECOQNIZED: " + quoteUnprintableLatin1(response));
|
|
|
|
|
acknowledgeResult();
|
|
|
|
|
} else if (n == 2 && tag == "F") { // flow control
|
|
|
|
|
m_congestion = parts.at(1).toInt();
|
|
|
|
|
SDEBUG("CONGESTION: " << m_congestion);
|
|
|
|
|
} else if (n == 4 && tag == "R") { // result data
|
|
|
|
|
acknowledgeResult();
|
|
|
|
|
int token = parts.at(1).toInt();
|
|
|
|
|
QByteArray message = parts.at(2);
|
|
|
|
|
QmlResponse data(parts.at(3));
|
|
|
|
|
showDebuggerOutput(LogOutput, QString("%1^%2%3").arg(token)
|
|
|
|
|
.arg(quoteUnprintableLatin1(response))
|
|
|
|
|
.arg(QString::fromUtf8(data.toString())));
|
|
|
|
|
QmlCommand tcf = m_cookieForToken[token];
|
|
|
|
|
QmlResponse result(data);
|
|
|
|
|
SDEBUG("GOOD RESPONSE: " << quoteUnprintableLatin1(response));
|
|
|
|
|
if (tcf.callback)
|
|
|
|
|
(this->*(tcf.callback))(result, tcf.cookie);
|
|
|
|
|
} else if (n == 3 && tag == "P") { // progress data (partial result)
|
|
|
|
|
//int token = parts.at(1).toInt();
|
|
|
|
|
QByteArray data = parts.at(2);
|
|
|
|
|
SDEBUG(_("\nTCF PARTIAL:") << quoteUnprintableLatin1(response));
|
|
|
|
|
} else if (n == 4 && tag == "E") { // an event
|
|
|
|
|
QByteArray service = parts.at(1);
|
|
|
|
|
QByteArray eventName = parts.at(2);
|
|
|
|
|
QmlResponse data(parts.at(3));
|
|
|
|
|
if (eventName != "peerHeartBeat")
|
|
|
|
|
SDEBUG(_("\nTCF EVENT:") << quoteUnprintableLatin1(response)
|
|
|
|
|
<< data.toString());
|
|
|
|
|
if (service == "Locator" && eventName == "Hello") {
|
|
|
|
|
m_services.clear();
|
|
|
|
|
foreach (const QmlResponse &service, data.children())
|
|
|
|
|
m_services.append(service.data());
|
|
|
|
|
QTimer::singleShot(0, this, SLOT(startDebugging()));
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
SDEBUG("UNKNOWN RESPONSE PACKET:"
|
|
|
|
|
<< quoteUnprintableLatin1(response) << parts);
|
|
|
|
|
}
|
|
|
|
|
*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::startDebugging()
|
|
|
|
|
{
|
|
|
|
|
qDebug() << "START";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::postCommand(const QByteArray &cmd,
|
|
|
|
|
QmlCommandCallback callback, const char *callbackName)
|
|
|
|
|
{
|
2010-06-11 16:31:54 +02:00
|
|
|
Q_UNUSED(cmd);
|
|
|
|
|
Q_UNUSED(callback);
|
|
|
|
|
Q_UNUSED(callbackName);
|
2010-06-09 16:13:47 +02:00
|
|
|
/*
|
|
|
|
|
static int token = 20;
|
|
|
|
|
++token;
|
|
|
|
|
|
|
|
|
|
//const char marker_eom = -1;
|
|
|
|
|
//const char marker_eos = -2;
|
|
|
|
|
//const char marker_null = -3;
|
|
|
|
|
|
|
|
|
|
QByteArray ba = "C";
|
|
|
|
|
ba.append('\0');
|
|
|
|
|
ba.append(QByteArray::number(token));
|
|
|
|
|
ba.append('\0');
|
|
|
|
|
ba.append(cmd);
|
|
|
|
|
ba.append('\0');
|
|
|
|
|
ba.append('\3');
|
|
|
|
|
ba.append('\1');
|
|
|
|
|
|
|
|
|
|
QmlCommand tcf;
|
|
|
|
|
tcf.command = ba;
|
|
|
|
|
tcf.callback = callback;
|
|
|
|
|
tcf.callbackName = callbackName;
|
|
|
|
|
tcf.token = token;
|
|
|
|
|
|
|
|
|
|
m_cookieForToken[token] = tcf;
|
|
|
|
|
|
|
|
|
|
enqueueCommand(tcf);
|
|
|
|
|
*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Congestion control does not seem to work that way. Basically it's
|
|
|
|
|
// already too late when we get a flow control packet
|
|
|
|
|
void QmlEngine::enqueueCommand(const QmlCommand &cmd)
|
|
|
|
|
{
|
2010-06-11 16:31:54 +02:00
|
|
|
Q_UNUSED(cmd);
|
2010-06-09 16:13:47 +02:00
|
|
|
/*
|
|
|
|
|
#ifdef USE_CONGESTION_CONTROL
|
|
|
|
|
// congestion controled
|
|
|
|
|
if (m_congestion <= 0 && m_sendQueue.isEmpty()) {
|
|
|
|
|
//SDEBUG("DIRECT SEND" << cmd.toString());
|
|
|
|
|
sendCommandNow(cmd);
|
|
|
|
|
} else {
|
|
|
|
|
SDEBUG("QUEUE " << cmd.toString());
|
|
|
|
|
m_sendQueue.enqueue(cmd);
|
|
|
|
|
m_sendTimer.start();
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
// synchrounously
|
|
|
|
|
if (m_inAir == 0)
|
|
|
|
|
sendCommandNow(cmd);
|
|
|
|
|
else
|
|
|
|
|
m_sendQueue.enqueue(cmd);
|
|
|
|
|
#endif
|
|
|
|
|
*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::handleSendTimer()
|
|
|
|
|
{
|
|
|
|
|
/*
|
|
|
|
|
QTC_ASSERT(!m_sendQueue.isEmpty(), return);
|
|
|
|
|
|
|
|
|
|
if (m_congestion > 0) {
|
|
|
|
|
// not ready...
|
|
|
|
|
SDEBUG("WAITING FOR CONGESTION TO GO DOWN...");
|
|
|
|
|
m_sendTimer.start();
|
|
|
|
|
} else {
|
|
|
|
|
// go!
|
|
|
|
|
sendCommandNow(m_sendQueue.dequeue());
|
|
|
|
|
}
|
|
|
|
|
*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::sendCommandNow(const QmlCommand &cmd)
|
|
|
|
|
{
|
|
|
|
|
++m_inAir;
|
|
|
|
|
int result = m_socket->write(cmd.command);
|
|
|
|
|
Q_UNUSED(result)
|
|
|
|
|
m_socket->flush();
|
2010-06-14 18:19:02 +02:00
|
|
|
showMessage(QString::number(cmd.token) + " " + cmd.toString(), LogInput);
|
2010-06-09 16:13:47 +02:00
|
|
|
SDEBUG("SEND " << cmd.toString()); //<< " " << QString::number(result));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::acknowledgeResult()
|
|
|
|
|
{
|
|
|
|
|
#if !defined(USE_CONGESTION_CONTROL)
|
|
|
|
|
QTC_ASSERT(m_inAir == 1, /**/);
|
|
|
|
|
m_inAir = 0;
|
|
|
|
|
if (!m_sendQueue.isEmpty())
|
|
|
|
|
sendCommandNow(m_sendQueue.dequeue());
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::handleRunControlSuspend(const QmlResponse &data, const QVariant &)
|
|
|
|
|
{
|
|
|
|
|
SDEBUG("HANDLE RESULT" << data.toString());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::handleRunControlGetChildren(const QmlResponse &data, const QVariant &)
|
|
|
|
|
{
|
|
|
|
|
SDEBUG("HANDLE RUN CONTROL GET CHILDREN" << data.toString());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::handleSysMonitorGetChildren(const QmlResponse &data, const QVariant &)
|
|
|
|
|
{
|
|
|
|
|
SDEBUG("HANDLE RUN CONTROL GET CHILDREN" << data.toString());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
|
|
|
|
// Tooltip specific stuff
|
|
|
|
|
//
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
static WatchData m_toolTip;
|
|
|
|
|
static QPoint m_toolTipPos;
|
|
|
|
|
static QHash<QString, WatchData> m_toolTipCache;
|
|
|
|
|
|
|
|
|
|
void QmlEngine::setToolTipExpression(const QPoint &mousePos, TextEditor::ITextEditor *editor, int cursorPos)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(mousePos)
|
|
|
|
|
Q_UNUSED(editor)
|
|
|
|
|
Q_UNUSED(cursorPos)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
|
|
|
|
// Watch specific stuff
|
|
|
|
|
//
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
void QmlEngine::assignValueInDebugger(const QString &expression,
|
|
|
|
|
const QString &value)
|
|
|
|
|
{
|
|
|
|
|
XSDEBUG("ASSIGNING: " << expression + '=' + value);
|
|
|
|
|
updateLocals();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::updateLocals()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::updateWatchData(const WatchData &)
|
|
|
|
|
{
|
|
|
|
|
//qq->watchHandler()->rebuildModel();
|
|
|
|
|
showStatusMessage(tr("Stopped."), 5000);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlEngine::updateSubItem(const WatchData &data0)
|
|
|
|
|
{
|
|
|
|
|
Q_UNUSED(data0)
|
|
|
|
|
QTC_ASSERT(false, return);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
IDebuggerEngine *createQmlEngine(DebuggerManager *manager)
|
|
|
|
|
{
|
|
|
|
|
return new QmlEngine(manager);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace Internal
|
|
|
|
|
} // namespace Debugger
|