forked from qt-creator/qt-creator
debugger: convert register handler/window architecture
This commit is contained in:
@@ -31,26 +31,20 @@
|
|||||||
#include "breakpointmarker.h"
|
#include "breakpointmarker.h"
|
||||||
|
|
||||||
#include "debuggeractions.h"
|
#include "debuggeractions.h"
|
||||||
#include "debuggerengine.h"
|
|
||||||
#include "debuggerplugin.h"
|
#include "debuggerplugin.h"
|
||||||
#include "debuggerstringutils.h"
|
#include "debuggerstringutils.h"
|
||||||
#include "threadshandler.h"
|
|
||||||
|
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
|
|
||||||
#include <QtCore/QDir>
|
#include <QtCore/QDir>
|
||||||
#include <QtCore/QFileInfo>
|
#include <QtCore/QFileInfo>
|
||||||
|
|
||||||
|
|
||||||
namespace Debugger {
|
namespace Debugger {
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
static DebuggerPlugin *plugin() { return DebuggerPlugin::instance(); }
|
static DebuggerPlugin *plugin() { return DebuggerPlugin::instance(); }
|
||||||
|
|
||||||
|
|
||||||
static Breakpoints m_bp;
|
|
||||||
// FIXME this is only static because it might map to bps in the above list
|
|
||||||
static QHash<quint64,BreakpointMarker*> m_markers;
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// BreakHandler
|
// BreakHandler
|
||||||
|
|||||||
@@ -117,7 +117,7 @@ private:
|
|||||||
QVariant headerData(int section, Qt::Orientation orientation, int role) const;
|
QVariant headerData(int section, Qt::Orientation orientation, int role) const;
|
||||||
Qt::ItemFlags flags(const QModelIndex &index) const;
|
Qt::ItemFlags flags(const QModelIndex &index) const;
|
||||||
|
|
||||||
void markerUpdated(BreakpointMarker *, int lineNumber);
|
void markerUpdated(BreakpointMarker *marker, int lineNumber);
|
||||||
void loadBreakpoints();
|
void loadBreakpoints();
|
||||||
void saveBreakpoints();
|
void saveBreakpoints();
|
||||||
void removeBreakpointHelper(int index);
|
void removeBreakpointHelper(int index);
|
||||||
@@ -138,7 +138,8 @@ private:
|
|||||||
mutable BreakpointData *m_lastFound;
|
mutable BreakpointData *m_lastFound;
|
||||||
mutable bool m_lastFoundQueried;
|
mutable bool m_lastFoundQueried;
|
||||||
|
|
||||||
QList<BreakpointData *> m_bp;
|
Breakpoints m_bp;
|
||||||
|
QHash<quint64, BreakpointMarker *> m_markers;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
|
|||||||
@@ -239,14 +239,6 @@ enum ModelRoles
|
|||||||
RequestAllSymbolsRole,
|
RequestAllSymbolsRole,
|
||||||
RequestOpenFileRole,
|
RequestOpenFileRole,
|
||||||
|
|
||||||
// Registers
|
|
||||||
RegisterNumberBaseRole, // Currently used number base
|
|
||||||
RegisterAddressRole, // Start value for opening memory view
|
|
||||||
RegisterChangedRole, // Used for painting changed values
|
|
||||||
RegisterBigNumberRole, // Register is a big integer that cannot be handled as quint64.
|
|
||||||
RequestSetRegisterRole,
|
|
||||||
RequestReloadRegistersRole,
|
|
||||||
|
|
||||||
// Snapshots
|
// Snapshots
|
||||||
SnapshotCapabilityRole,
|
SnapshotCapabilityRole,
|
||||||
RequestCreateSnapshotRole,
|
RequestCreateSnapshotRole,
|
||||||
|
|||||||
@@ -225,7 +225,7 @@ public:
|
|||||||
m_targetState(DebuggerNotReady),
|
m_targetState(DebuggerNotReady),
|
||||||
m_commandHandler(engine),
|
m_commandHandler(engine),
|
||||||
m_modulesHandler(engine),
|
m_modulesHandler(engine),
|
||||||
m_registerHandler(engine),
|
m_registerHandler(),
|
||||||
m_sourceFilesHandler(engine),
|
m_sourceFilesHandler(engine),
|
||||||
m_stackHandler(engine),
|
m_stackHandler(engine),
|
||||||
m_threadsHandler(engine),
|
m_threadsHandler(engine),
|
||||||
@@ -534,9 +534,9 @@ void DebuggerEngine::handleCommand(int role, const QVariant &value)
|
|||||||
reloadModules();
|
reloadModules();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RequestReloadRegistersRole:
|
//case RequestReloadRegistersRole:
|
||||||
reloadRegisters();
|
// reloadRegisters();
|
||||||
break;
|
// break;
|
||||||
|
|
||||||
case RequestExecDetachRole:
|
case RequestExecDetachRole:
|
||||||
detachDebugger();
|
detachDebugger();
|
||||||
|
|||||||
@@ -863,8 +863,12 @@ public slots:
|
|||||||
{ if (on) notifyCurrentEngine(RequestReloadSourceFilesRole); }
|
{ if (on) notifyCurrentEngine(RequestReloadSourceFilesRole); }
|
||||||
void modulesDockToggled(bool on)
|
void modulesDockToggled(bool on)
|
||||||
{ if (on) notifyCurrentEngine(RequestReloadModulesRole); }
|
{ if (on) notifyCurrentEngine(RequestReloadModulesRole); }
|
||||||
|
|
||||||
void registerDockToggled(bool on)
|
void registerDockToggled(bool on)
|
||||||
{ if (on) notifyCurrentEngine(RequestReloadRegistersRole); }
|
{
|
||||||
|
if (on && m_currentEngine)
|
||||||
|
m_currentEngine->reloadRegisters();
|
||||||
|
}
|
||||||
|
|
||||||
void synchronizeBreakpoints()
|
void synchronizeBreakpoints()
|
||||||
{
|
{
|
||||||
@@ -2059,14 +2063,40 @@ void DebuggerPluginPrivate::startDebugger(RunControl *rc)
|
|||||||
ProjectExplorerPlugin::instance()->startRunControl(rc, PE::DEBUGMODE);
|
ProjectExplorerPlugin::instance()->startRunControl(rc, PE::DEBUGMODE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class DummyEngine : public DebuggerEngine
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
DummyEngine() : DebuggerEngine(DebuggerStartParameters()) {}
|
||||||
|
virtual ~DummyEngine() {}
|
||||||
|
|
||||||
|
virtual void setupEngine() {}
|
||||||
|
virtual void setupInferior() {}
|
||||||
|
virtual void runEngine() {}
|
||||||
|
virtual void shutdownEngine() {}
|
||||||
|
virtual void shutdownInferior() {}
|
||||||
|
virtual void executeDebuggerCommand(const QString &) {}
|
||||||
|
virtual unsigned debuggerCapabilities() const { return 0; }
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
void DebuggerPluginPrivate::connectEngine(DebuggerEngine *engine, bool notify)
|
void DebuggerPluginPrivate::connectEngine(DebuggerEngine *engine, bool notify)
|
||||||
{
|
{
|
||||||
|
static Debugger::DummyEngine dummyEngine;
|
||||||
|
|
||||||
|
if (!engine)
|
||||||
|
engine = &dummyEngine;
|
||||||
|
|
||||||
if (m_currentEngine == engine)
|
if (m_currentEngine == engine)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (engine) {
|
m_currentEngine = engine;
|
||||||
|
|
||||||
if (notify)
|
if (notify)
|
||||||
notifyCurrentEngine(RequestActivationRole, false);
|
notifyCurrentEngine(RequestActivationRole, false);
|
||||||
|
|
||||||
m_commandWindow->setModel(engine->commandModel());
|
m_commandWindow->setModel(engine->commandModel());
|
||||||
m_localsWindow->setModel(engine->localsModel());
|
m_localsWindow->setModel(engine->localsModel());
|
||||||
m_modulesWindow->setModel(engine->modulesModel());
|
m_modulesWindow->setModel(engine->modulesModel());
|
||||||
@@ -2078,21 +2108,9 @@ void DebuggerPluginPrivate::connectEngine(DebuggerEngine *engine, bool notify)
|
|||||||
m_threadBox->setModel(engine->threadsModel());
|
m_threadBox->setModel(engine->threadsModel());
|
||||||
m_threadBox->setModelColumn(ThreadData::NameColumn);
|
m_threadBox->setModelColumn(ThreadData::NameColumn);
|
||||||
m_watchersWindow->setModel(engine->watchersModel());
|
m_watchersWindow->setModel(engine->watchersModel());
|
||||||
|
|
||||||
if (notify)
|
if (notify)
|
||||||
notifyCurrentEngine(RequestActivationRole, true);
|
notifyCurrentEngine(RequestActivationRole, true);
|
||||||
} else {
|
|
||||||
m_commandWindow->setModel(0);
|
|
||||||
m_localsWindow->setModel(0);
|
|
||||||
m_modulesWindow->setModel(0);
|
|
||||||
m_registerWindow->setModel(0);
|
|
||||||
m_returnWindow->setModel(0);
|
|
||||||
m_sourceFilesWindow->setModel(0);
|
|
||||||
m_stackWindow->setModel(0);
|
|
||||||
m_threadsWindow->setModel(0);
|
|
||||||
m_threadBox->setModel(0);
|
|
||||||
m_threadBox->setModelColumn(ThreadData::NameColumn);
|
|
||||||
m_watchersWindow->setModel(0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void changeFontSize(QWidget *widget, qreal size)
|
static void changeFontSize(QWidget *widget, qreal size)
|
||||||
@@ -2856,6 +2874,11 @@ Internal::BreakHandler *DebuggerPlugin::breakHandler() const
|
|||||||
return d->m_breakHandler;
|
return d->m_breakHandler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DebuggerEngine *DebuggerPlugin::currentEngine() const
|
||||||
|
{
|
||||||
|
return d->m_currentEngine;
|
||||||
|
}
|
||||||
|
|
||||||
void DebuggerPlugin::remoteCommand(const QStringList &options, const QStringList &)
|
void DebuggerPlugin::remoteCommand(const QStringList &options, const QStringList &)
|
||||||
{
|
{
|
||||||
if (options.isEmpty())
|
if (options.isEmpty())
|
||||||
|
|||||||
@@ -91,6 +91,7 @@ public:
|
|||||||
|
|
||||||
void openTextEditor(const QString &titlePattern, const QString &contents);
|
void openTextEditor(const QString &titlePattern, const QString &contents);
|
||||||
Internal::BreakHandler *breakHandler() const;
|
Internal::BreakHandler *breakHandler() const;
|
||||||
|
DebuggerEngine *currentEngine() const;
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void clearCppCodeModelSnapshot();
|
void clearCppCodeModelSnapshot();
|
||||||
|
|||||||
@@ -28,24 +28,8 @@
|
|||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
#include "registerhandler.h"
|
#include "registerhandler.h"
|
||||||
|
|
||||||
#include "debuggeractions.h"
|
|
||||||
#include "debuggeragents.h"
|
|
||||||
#include "debuggerconstants.h"
|
|
||||||
#include "debuggerengine.h"
|
|
||||||
#include "watchdelegatewidgets.h"
|
#include "watchdelegatewidgets.h"
|
||||||
|
|
||||||
#include <utils/qtcassert.h>
|
|
||||||
|
|
||||||
#include <QtCore/QAbstractTableModel>
|
|
||||||
#include <QtCore/QDebug>
|
|
||||||
|
|
||||||
#include <QtGui/QColor>
|
|
||||||
|
|
||||||
using namespace Debugger;
|
|
||||||
using namespace Debugger::Internal;
|
|
||||||
using namespace Debugger::Constants;
|
|
||||||
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
@@ -53,8 +37,11 @@ using namespace Debugger::Constants;
|
|||||||
//
|
//
|
||||||
//////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
RegisterHandler::RegisterHandler(DebuggerEngine *engine)
|
namespace Debugger {
|
||||||
: m_engine(engine), m_base(15)
|
namespace Internal {
|
||||||
|
|
||||||
|
RegisterHandler::RegisterHandler()
|
||||||
|
: m_base(-1)
|
||||||
{
|
{
|
||||||
setNumberBase(16);
|
setNumberBase(16);
|
||||||
}
|
}
|
||||||
@@ -70,53 +57,36 @@ int RegisterHandler::columnCount(const QModelIndex &parent) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Editor value: Preferably number, else string.
|
// Editor value: Preferably number, else string.
|
||||||
QVariant RegisterHandler::editValue(const Register ®)
|
QVariant Register::editValue() const
|
||||||
{
|
{
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
// Try to convert to number?
|
// Try to convert to number?
|
||||||
const qulonglong value = reg.value.toULongLong(&ok, 0); // Autodetect format
|
const qulonglong v = value.toULongLong(&ok, 0); // Autodetect format
|
||||||
if (ok)
|
if (ok)
|
||||||
|
return QVariant(v);
|
||||||
return QVariant(value);
|
return QVariant(value);
|
||||||
return QVariant(reg.value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Editor value: Preferably padded number, else padded string.
|
// Editor value: Preferably padded number, else padded string.
|
||||||
inline QString RegisterHandler::displayValue(const Register ®) const
|
QString Register::displayValue(int base, int strlen) const
|
||||||
{
|
{
|
||||||
const QVariant editV = RegisterHandler::editValue(reg);
|
const QVariant editV = editValue();
|
||||||
if (editV.type() == QVariant::ULongLong)
|
if (editV.type() == QVariant::ULongLong)
|
||||||
return QString::fromAscii("%1").arg(editV.toULongLong(), m_strlen, m_base);
|
return QString::fromAscii("%1").arg(editV.toULongLong(), strlen, base);
|
||||||
const QString stringValue = editV.toString();
|
const QString stringValue = editV.toString();
|
||||||
if (stringValue.size() < m_strlen)
|
if (stringValue.size() < strlen)
|
||||||
return QString(m_strlen - stringValue.size(), QLatin1Char(' ')) + reg.value;
|
return QString(strlen - stringValue.size(), QLatin1Char(' ')) + value;
|
||||||
return stringValue;
|
return stringValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
QVariant RegisterHandler::data(const QModelIndex &index, int role) const
|
QVariant RegisterHandler::data(const QModelIndex &index, int role) const
|
||||||
{
|
{
|
||||||
switch (role) {
|
|
||||||
case EngineStateRole:
|
|
||||||
return m_engine->state();
|
|
||||||
|
|
||||||
case EngineCapabilitiesRole:
|
|
||||||
return m_engine->debuggerCapabilities();
|
|
||||||
|
|
||||||
case EngineActionsEnabledRole:
|
|
||||||
return m_engine->debuggerActionsEnabled();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!index.isValid() || index.row() >= m_registers.size())
|
if (!index.isValid() || index.row() >= m_registers.size())
|
||||||
return QVariant();
|
return QVariant();
|
||||||
|
|
||||||
const Register ® = m_registers.at(index.row());
|
const Register ® = m_registers.at(index.row());
|
||||||
|
|
||||||
switch (role) {
|
switch (role) {
|
||||||
case RegisterAddressRole: {
|
|
||||||
// Return some address associated with the register. Autodetect format
|
|
||||||
const QVariant editV = RegisterHandler::editValue(reg);
|
|
||||||
return editV.type() == QVariant::ULongLong ? editV : QVariant();
|
|
||||||
}
|
|
||||||
|
|
||||||
case Qt::DisplayRole:
|
case Qt::DisplayRole:
|
||||||
switch (index.column()) {
|
switch (index.column()) {
|
||||||
case 0: {
|
case 0: {
|
||||||
@@ -124,18 +94,12 @@ QVariant RegisterHandler::data(const QModelIndex &index, int role) const
|
|||||||
return QVariant(padding + reg.name + padding);
|
return QVariant(padding + reg.name + padding);
|
||||||
}
|
}
|
||||||
case 1: // Display: Pad value for alignment
|
case 1: // Display: Pad value for alignment
|
||||||
return displayValue(reg);
|
return reg.displayValue(m_base, m_strlen);
|
||||||
} // switch column
|
} // switch column
|
||||||
case Qt::EditRole: // Edit: Unpadded for editing
|
case Qt::EditRole: // Edit: Unpadded for editing
|
||||||
return RegisterHandler::editValue(reg);
|
return reg.editValue();
|
||||||
case Qt::TextAlignmentRole:
|
case Qt::TextAlignmentRole:
|
||||||
return index.column() == 1 ? QVariant(Qt::AlignRight) : QVariant();
|
return index.column() == 1 ? QVariant(Qt::AlignRight) : QVariant();
|
||||||
case RegisterChangedRole:
|
|
||||||
return QVariant(reg.changed);
|
|
||||||
case RegisterBigNumberRole: // Editor: Can it be handled as quint64?
|
|
||||||
return editValue(reg).type() != QVariant::ULongLong;
|
|
||||||
case RegisterNumberBaseRole: // Big integers are assumed to be hexadecimal
|
|
||||||
return editValue(reg).type() == QVariant::ULongLong ? m_base : 16;
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -161,31 +125,12 @@ Qt::ItemFlags RegisterHandler::flags(const QModelIndex &idx) const
|
|||||||
|
|
||||||
const Qt::ItemFlags notEditable = Qt::ItemIsSelectable|Qt::ItemIsEnabled;
|
const Qt::ItemFlags notEditable = Qt::ItemIsSelectable|Qt::ItemIsEnabled;
|
||||||
// Can edit registers if they are hex numbers and not arrays.
|
// Can edit registers if they are hex numbers and not arrays.
|
||||||
if (idx.column() == 1 && IntegerWatchLineEdit::isUnsignedHexNumber(m_registers.at(idx.row()).value))
|
if (idx.column() == 1
|
||||||
|
&& IntegerWatchLineEdit::isUnsignedHexNumber(m_registers.at(idx.row()).value))
|
||||||
return notEditable | Qt::ItemIsEditable;
|
return notEditable | Qt::ItemIsEditable;
|
||||||
return notEditable;
|
return notEditable;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RegisterHandler::setData(const QModelIndex &index, const QVariant &value, int role)
|
|
||||||
{
|
|
||||||
switch (role) {
|
|
||||||
case RequestSetRegisterRole:
|
|
||||||
m_engine->setRegisterValue(index.row(), value.toString());
|
|
||||||
return true;
|
|
||||||
|
|
||||||
case RequestReloadRegistersRole:
|
|
||||||
m_engine->reloadRegisters();
|
|
||||||
return true;
|
|
||||||
|
|
||||||
case RequestShowMemoryRole:
|
|
||||||
(void) new MemoryViewAgent(m_engine, value.toString());
|
|
||||||
return true;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return QAbstractTableModel::setData(index, value, role);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void RegisterHandler::removeAll()
|
void RegisterHandler::removeAll()
|
||||||
{
|
{
|
||||||
m_registers.clear();
|
m_registers.clear();
|
||||||
@@ -232,3 +177,6 @@ void RegisterHandler::setNumberBase(int base)
|
|||||||
emit reset();
|
emit reset();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} // namespace Internal
|
||||||
|
} // namespace Debugger
|
||||||
|
|||||||
@@ -34,14 +34,16 @@
|
|||||||
#include <QtCore/QVector>
|
#include <QtCore/QVector>
|
||||||
|
|
||||||
namespace Debugger {
|
namespace Debugger {
|
||||||
class DebuggerEngine;
|
|
||||||
|
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
class Register
|
class Register
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Register() : changed(true) {}
|
Register() : changed(true) {}
|
||||||
Register(QByteArray const &name_) : name(name_), changed(true) {}
|
Register(const QByteArray &name_) : name(name_), changed(true) {}
|
||||||
|
|
||||||
|
QVariant editValue() const;
|
||||||
|
QString displayValue(int base, int strlen) const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
QByteArray name;
|
QByteArray name;
|
||||||
@@ -60,7 +62,7 @@ class RegisterHandler : public QAbstractTableModel
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit RegisterHandler(DebuggerEngine *engine);
|
RegisterHandler();
|
||||||
|
|
||||||
QAbstractItemModel *model() { return this; }
|
QAbstractItemModel *model() { return this; }
|
||||||
|
|
||||||
@@ -68,22 +70,20 @@ public:
|
|||||||
void setRegisters(const Registers ®isters);
|
void setRegisters(const Registers ®isters);
|
||||||
void setAndMarkRegisters(const Registers ®isters);
|
void setAndMarkRegisters(const Registers ®isters);
|
||||||
Registers registers() const;
|
Registers registers() const;
|
||||||
|
Register registerAt(int i) const { return m_registers.at(i); }
|
||||||
void removeAll();
|
void removeAll();
|
||||||
Q_SLOT void setNumberBase(int base);
|
Q_SLOT void setNumberBase(int base);
|
||||||
|
int numberBase() const { return m_base; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void calculateWidth();
|
void calculateWidth();
|
||||||
inline QString displayValue(const Register ®) const;
|
|
||||||
static QVariant editValue(const Register ®);
|
|
||||||
int rowCount(const QModelIndex &parent = QModelIndex()) const;
|
int rowCount(const QModelIndex &parent = QModelIndex()) const;
|
||||||
int columnCount(const QModelIndex &parent = QModelIndex()) const;
|
int columnCount(const QModelIndex &parent = QModelIndex()) const;
|
||||||
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const;
|
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const;
|
||||||
bool setData(const QModelIndex &index, const QVariant &, int role);
|
|
||||||
QVariant headerData(int section, Qt::Orientation orientation,
|
QVariant headerData(int section, Qt::Orientation orientation,
|
||||||
int role = Qt::DisplayRole) const;
|
int role = Qt::DisplayRole) const;
|
||||||
Qt::ItemFlags flags(const QModelIndex &idx) const;
|
Qt::ItemFlags flags(const QModelIndex &idx) const;
|
||||||
|
|
||||||
DebuggerEngine *m_engine; // Not owned.
|
|
||||||
Registers m_registers;
|
Registers m_registers;
|
||||||
int m_base;
|
int m_base;
|
||||||
int m_strlen; // approximate width of a value in chars.
|
int m_strlen; // approximate width of a value in chars.
|
||||||
|
|||||||
@@ -30,8 +30,11 @@
|
|||||||
#include "registerwindow.h"
|
#include "registerwindow.h"
|
||||||
|
|
||||||
#include "debuggeractions.h"
|
#include "debuggeractions.h"
|
||||||
|
#include "debuggerplugin.h"
|
||||||
|
#include "debuggeragents.h"
|
||||||
#include "debuggerconstants.h"
|
#include "debuggerconstants.h"
|
||||||
|
#include "debuggerengine.h"
|
||||||
|
#include "registerhandler.h"
|
||||||
#include "watchdelegatewidgets.h"
|
#include "watchdelegatewidgets.h"
|
||||||
|
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
@@ -45,9 +48,22 @@
|
|||||||
#include <QtGui/QPainter>
|
#include <QtGui/QPainter>
|
||||||
#include <QtGui/QResizeEvent>
|
#include <QtGui/QResizeEvent>
|
||||||
|
|
||||||
|
|
||||||
namespace Debugger {
|
namespace Debugger {
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
|
static DebuggerEngine *currentEngine()
|
||||||
|
{
|
||||||
|
return DebuggerPlugin::instance()->currentEngine();
|
||||||
|
}
|
||||||
|
|
||||||
|
static RegisterHandler *currentHandler()
|
||||||
|
{
|
||||||
|
DebuggerEngine *engine = currentEngine();
|
||||||
|
QTC_ASSERT(engine, return 0);
|
||||||
|
return engine->registerHandler();
|
||||||
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// RegisterDelegate
|
// RegisterDelegate
|
||||||
@@ -57,18 +73,21 @@ namespace Internal {
|
|||||||
class RegisterDelegate : public QItemDelegate
|
class RegisterDelegate : public QItemDelegate
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RegisterDelegate(RegisterWindow *owner, QObject *parent)
|
RegisterDelegate(QObject *parent)
|
||||||
: QItemDelegate(parent), m_owner(owner)
|
: QItemDelegate(parent)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &,
|
QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &,
|
||||||
const QModelIndex &index) const
|
const QModelIndex &index) const
|
||||||
{
|
{
|
||||||
|
Register reg = currentHandler()->registerAt(index.row());
|
||||||
IntegerWatchLineEdit *lineEdit = new IntegerWatchLineEdit(parent);
|
IntegerWatchLineEdit *lineEdit = new IntegerWatchLineEdit(parent);
|
||||||
lineEdit->setBase(index.data(RegisterNumberBaseRole).toInt());
|
const int base = currentHandler()->numberBase();
|
||||||
lineEdit->setBigInt(index.data(RegisterBigNumberRole).toBool());
|
const bool big = reg.value.size() > 16;
|
||||||
|
// Big integers are assumed to be hexadecimal.
|
||||||
|
lineEdit->setBigInt(big);
|
||||||
|
lineEdit->setBase(big ? 16 : base);
|
||||||
lineEdit->setSigned(false);
|
lineEdit->setSigned(false);
|
||||||
|
|
||||||
lineEdit->setAlignment(Qt::AlignRight);
|
lineEdit->setAlignment(Qt::AlignRight);
|
||||||
return lineEdit;
|
return lineEdit;
|
||||||
}
|
}
|
||||||
@@ -80,13 +99,14 @@ public:
|
|||||||
lineEdit->setModelData(index.data(Qt::EditRole));
|
lineEdit->setModelData(index.data(Qt::EditRole));
|
||||||
}
|
}
|
||||||
|
|
||||||
void setModelData(QWidget *editor, QAbstractItemModel *, const QModelIndex &index) const
|
void setModelData(QWidget *editor, QAbstractItemModel *,
|
||||||
|
const QModelIndex &index) const
|
||||||
{
|
{
|
||||||
if (index.column() != 1)
|
if (index.column() != 1)
|
||||||
return;
|
return;
|
||||||
IntegerWatchLineEdit *lineEdit = qobject_cast<IntegerWatchLineEdit*>(editor);
|
IntegerWatchLineEdit *lineEdit = qobject_cast<IntegerWatchLineEdit*>(editor);
|
||||||
QTC_ASSERT(lineEdit, return);
|
QTC_ASSERT(lineEdit, return);
|
||||||
m_owner->model()->setData(index, lineEdit->modelData(), RequestSetRegisterRole);
|
currentEngine()->setRegisterValue(index.row(), lineEdit->text());
|
||||||
}
|
}
|
||||||
|
|
||||||
void updateEditorGeometry(QWidget *editor, const QStyleOptionViewItem &option,
|
void updateEditorGeometry(QWidget *editor, const QStyleOptionViewItem &option,
|
||||||
@@ -99,7 +119,7 @@ public:
|
|||||||
const QModelIndex &index) const
|
const QModelIndex &index) const
|
||||||
{
|
{
|
||||||
if (index.column() == 1) {
|
if (index.column() == 1) {
|
||||||
bool paintRed = index.data(RegisterChangedRole).toBool();
|
bool paintRed = currentHandler()->registerAt(index.row()).changed;
|
||||||
QPen oldPen = painter->pen();
|
QPen oldPen = painter->pen();
|
||||||
if (paintRed)
|
if (paintRed)
|
||||||
painter->setPen(QColor(200, 0, 0));
|
painter->setPen(QColor(200, 0, 0));
|
||||||
@@ -125,9 +145,6 @@ public:
|
|||||||
QItemDelegate::paint(painter, option, index);
|
QItemDelegate::paint(painter, option, index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
|
||||||
RegisterWindow *m_owner;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -146,10 +163,10 @@ RegisterWindow::RegisterWindow(QWidget *parent)
|
|||||||
setAttribute(Qt::WA_MacShowFocusRect, false);
|
setAttribute(Qt::WA_MacShowFocusRect, false);
|
||||||
setAlternatingRowColors(act->isChecked());
|
setAlternatingRowColors(act->isChecked());
|
||||||
setRootIsDecorated(false);
|
setRootIsDecorated(false);
|
||||||
setItemDelegate(new RegisterDelegate(this, this));
|
setItemDelegate(new RegisterDelegate(this));
|
||||||
|
|
||||||
connect(act, SIGNAL(toggled(bool)),
|
connect(act, SIGNAL(toggled(bool)),
|
||||||
this, SLOT(setAlternatingRowColorsHelper(bool)));
|
SLOT(setAlternatingRowColorsHelper(bool)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterWindow::resizeEvent(QResizeEvent *ev)
|
void RegisterWindow::resizeEvent(QResizeEvent *ev)
|
||||||
@@ -161,9 +178,12 @@ void RegisterWindow::contextMenuEvent(QContextMenuEvent *ev)
|
|||||||
{
|
{
|
||||||
QMenu menu;
|
QMenu menu;
|
||||||
|
|
||||||
const unsigned engineCapabilities = modelData(EngineCapabilitiesRole).toUInt();
|
DebuggerEngine *engine = currentEngine();
|
||||||
const bool actionsEnabled = modelData(EngineActionsEnabledRole).toInt();
|
QTC_ASSERT(engine, return);
|
||||||
const int state = modelData(EngineStateRole).toInt();
|
RegisterHandler *handler = currentHandler();
|
||||||
|
const unsigned engineCapabilities = engine->debuggerCapabilities();
|
||||||
|
const bool actionsEnabled = engine->debuggerActionsEnabled();
|
||||||
|
const int state = engine->state();
|
||||||
|
|
||||||
QAction *actReload = menu.addAction(tr("Reload Register Listing"));
|
QAction *actReload = menu.addAction(tr("Reload Register Listing"));
|
||||||
actReload->setEnabled((engineCapabilities & RegisterCapability)
|
actReload->setEnabled((engineCapabilities & RegisterCapability)
|
||||||
@@ -172,7 +192,7 @@ void RegisterWindow::contextMenuEvent(QContextMenuEvent *ev)
|
|||||||
menu.addSeparator();
|
menu.addSeparator();
|
||||||
|
|
||||||
QModelIndex idx = indexAt(ev->pos());
|
QModelIndex idx = indexAt(ev->pos());
|
||||||
QString address = modelData(RegisterAddressRole, idx).toString();
|
QString address = handler->registers().at(idx.row()).value;
|
||||||
QAction *actShowMemory = menu.addAction(QString());
|
QAction *actShowMemory = menu.addAction(QString());
|
||||||
if (address.isEmpty()) {
|
if (address.isEmpty()) {
|
||||||
actShowMemory->setText(tr("Open Memory Editor"));
|
actShowMemory->setText(tr("Open Memory Editor"));
|
||||||
@@ -184,7 +204,7 @@ void RegisterWindow::contextMenuEvent(QContextMenuEvent *ev)
|
|||||||
}
|
}
|
||||||
menu.addSeparator();
|
menu.addSeparator();
|
||||||
|
|
||||||
int base = modelData(RegisterNumberBaseRole).toInt();
|
const int base = handler->numberBase();
|
||||||
QAction *act16 = menu.addAction(tr("Hexadecimal"));
|
QAction *act16 = menu.addAction(tr("Hexadecimal"));
|
||||||
act16->setCheckable(true);
|
act16->setCheckable(true);
|
||||||
act16->setChecked(base == 16);
|
act16->setChecked(base == 16);
|
||||||
@@ -215,13 +235,17 @@ void RegisterWindow::contextMenuEvent(QContextMenuEvent *ev)
|
|||||||
else if (act == actAlwaysAdjust)
|
else if (act == actAlwaysAdjust)
|
||||||
setAlwaysResizeColumnsToContents(!m_alwaysResizeColumnsToContents);
|
setAlwaysResizeColumnsToContents(!m_alwaysResizeColumnsToContents);
|
||||||
else if (act == actReload)
|
else if (act == actReload)
|
||||||
setModelData(RequestReloadRegistersRole);
|
engine->reloadRegisters();
|
||||||
else if (act == actShowMemory)
|
else if (act == actShowMemory)
|
||||||
setModelData(RequestShowMemoryRole, address);
|
(void) new MemoryViewAgent(engine, address);
|
||||||
else if (act) {
|
else if (act == act16)
|
||||||
base = (act == act10 ? 10 : act == act8 ? 8 : act == act2 ? 2 : 16);
|
handler->setNumberBase(16);
|
||||||
QMetaObject::invokeMethod(model(), "setNumberBase", Q_ARG(int, base));
|
else if (act == act10)
|
||||||
}
|
handler->setNumberBase(10);
|
||||||
|
else if (act == act8)
|
||||||
|
handler->setNumberBase(8);
|
||||||
|
else if (act == act2)
|
||||||
|
handler->setNumberBase(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterWindow::resizeColumnsToContents()
|
void RegisterWindow::resizeColumnsToContents()
|
||||||
@@ -248,20 +272,7 @@ void RegisterWindow::setModel(QAbstractItemModel *model)
|
|||||||
void RegisterWindow::reloadRegisters()
|
void RegisterWindow::reloadRegisters()
|
||||||
{
|
{
|
||||||
// FIXME: Only trigger when becoming visible?
|
// FIXME: Only trigger when becoming visible?
|
||||||
setModelData(RequestReloadRegistersRole);
|
currentEngine()->reloadRegisters();
|
||||||
}
|
|
||||||
|
|
||||||
void RegisterWindow::setModelData
|
|
||||||
(int role, const QVariant &value, const QModelIndex &index)
|
|
||||||
{
|
|
||||||
QTC_ASSERT(model(), return);
|
|
||||||
model()->setData(index, value, role);
|
|
||||||
}
|
|
||||||
|
|
||||||
QVariant RegisterWindow::modelData(int role, const QModelIndex &index)
|
|
||||||
{
|
|
||||||
QTC_ASSERT(model(), return QVariant());
|
|
||||||
return model()->data(index, role);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
|
|||||||
@@ -53,10 +53,6 @@ private:
|
|||||||
void resizeEvent(QResizeEvent *ev);
|
void resizeEvent(QResizeEvent *ev);
|
||||||
void contextMenuEvent(QContextMenuEvent *ev);
|
void contextMenuEvent(QContextMenuEvent *ev);
|
||||||
|
|
||||||
void setModelData(int role, const QVariant &value = QVariant(),
|
|
||||||
const QModelIndex &index = QModelIndex());
|
|
||||||
QVariant modelData(int role, const QModelIndex &index = QModelIndex());
|
|
||||||
|
|
||||||
bool m_alwaysResizeColumnsToContents;
|
bool m_alwaysResizeColumnsToContents;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -64,4 +60,3 @@ private:
|
|||||||
} // namespace Debugger
|
} // namespace Debugger
|
||||||
|
|
||||||
#endif // DEBUGGER_REGISTERWINDOW_H
|
#endif // DEBUGGER_REGISTERWINDOW_H
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user