forked from qt-creator/qt-creator
debugger: more uiswitcher cleanup
further disentangling of debugger dockwidget updates remove unneeded variable make updateDockWidgetSettings private make dockwidget eventfilter slightly less heavy
This commit is contained in:
@@ -113,6 +113,8 @@ public:
|
|||||||
virtual QString gdbBinaryForToolChain(int toolChain) const = 0;
|
virtual QString gdbBinaryForToolChain(int toolChain) const = 0;
|
||||||
virtual void showModuleSymbols(const QString &moduleName,
|
virtual void showModuleSymbols(const QString &moduleName,
|
||||||
const QVector<Symbol> &symbols) = 0;
|
const QVector<Symbol> &symbols) = 0;
|
||||||
|
virtual void openMemoryEditor() = 0;
|
||||||
|
virtual void languagesChanged() = 0;
|
||||||
|
|
||||||
virtual Utils::SavedAction *action(int code) const = 0;
|
virtual Utils::SavedAction *action(int code) const = 0;
|
||||||
virtual bool boolSetting(int code) const = 0;
|
virtual bool boolSetting(int code) const = 0;
|
||||||
|
|||||||
@@ -28,7 +28,7 @@
|
|||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
#include "debuggermainwindow.h"
|
#include "debuggermainwindow.h"
|
||||||
#include "debuggerplugin.h"
|
#include "debuggercore.h"
|
||||||
|
|
||||||
#include <utils/styledbar.h>
|
#include <utils/styledbar.h>
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
@@ -76,31 +76,13 @@ namespace Internal {
|
|||||||
|
|
||||||
class DockWidgetEventFilter : public QObject
|
class DockWidgetEventFilter : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit DockWidgetEventFilter(QObject *parent = 0) : QObject(parent) {}
|
DockWidgetEventFilter(DebuggerMainWindowPrivate *mw) : m_mw(mw) {}
|
||||||
|
private:
|
||||||
signals:
|
|
||||||
void widgetResized();
|
|
||||||
|
|
||||||
protected:
|
|
||||||
virtual bool eventFilter(QObject *obj, QEvent *event);
|
virtual bool eventFilter(QObject *obj, QEvent *event);
|
||||||
|
DebuggerMainWindowPrivate *m_mw;
|
||||||
};
|
};
|
||||||
|
|
||||||
bool DockWidgetEventFilter::eventFilter(QObject *obj, QEvent *event)
|
|
||||||
{
|
|
||||||
switch (event->type()) {
|
|
||||||
case QEvent::Resize:
|
|
||||||
case QEvent::ZOrderChange:
|
|
||||||
emit widgetResized();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return QObject::eventFilter(obj, event);
|
|
||||||
}
|
|
||||||
|
|
||||||
class DebuggerMainWindowPrivate : public QObject
|
class DebuggerMainWindowPrivate : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@@ -110,24 +92,24 @@ public:
|
|||||||
|
|
||||||
void activateQmlCppLayout();
|
void activateQmlCppLayout();
|
||||||
void activateCppLayout();
|
void activateCppLayout();
|
||||||
void hideInactiveWidgets();
|
|
||||||
void createViewsMenuItems();
|
void createViewsMenuItems();
|
||||||
bool isQmlCppActive() const;
|
bool isQmlCppActive() const;
|
||||||
bool isQmlActive() const;
|
bool isQmlActive() const;
|
||||||
void setSimpleDockWidgetArrangement();
|
void setSimpleDockWidgetArrangement();
|
||||||
void updateUi();
|
|
||||||
// Debuggable languages are registered with this function.
|
// Debuggable languages are registered with this function.
|
||||||
void addLanguage(const DebuggerLanguage &language, const Core::Context &context);
|
void addLanguage(const DebuggerLanguage &language, const Core::Context &context);
|
||||||
|
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void resetDebuggerLayout();
|
void resetDebuggerLayout();
|
||||||
|
|
||||||
void updateUiForProject(ProjectExplorer::Project *project);
|
void updateUiForProject(ProjectExplorer::Project *project);
|
||||||
void updateUiForTarget(ProjectExplorer::Target *target);
|
void updateUiForTarget(ProjectExplorer::Target *target);
|
||||||
void updateUiForRunConfiguration(ProjectExplorer::RunConfiguration *rc);
|
void updateUiForRunConfiguration(ProjectExplorer::RunConfiguration *rc);
|
||||||
void updateUiForCurrentRunConfiguration();
|
void updateUiForCurrentRunConfiguration();
|
||||||
|
void updateActiveLanguages();
|
||||||
void updateUiOnFileListChange();
|
void updateUiOnFileListChange();
|
||||||
|
void updateDockWidgetSettings();
|
||||||
|
void openMemoryEditor() { debuggerCore()->openMemoryEditor(); }
|
||||||
|
|
||||||
public:
|
public:
|
||||||
DebuggerMainWindow *q;
|
DebuggerMainWindow *q;
|
||||||
@@ -135,12 +117,11 @@ public:
|
|||||||
|
|
||||||
QHash<QString, QVariant> m_dockWidgetActiveStateCpp;
|
QHash<QString, QVariant> m_dockWidgetActiveStateCpp;
|
||||||
QHash<QString, QVariant> m_dockWidgetActiveStateQmlCpp;
|
QHash<QString, QVariant> m_dockWidgetActiveStateQmlCpp;
|
||||||
Internal::DockWidgetEventFilter *m_resizeEventFilter;
|
DockWidgetEventFilter m_resizeEventFilter;
|
||||||
|
|
||||||
QMap<DebuggerLanguage, QWidget *> m_toolBars;
|
QMap<DebuggerLanguage, QWidget *> m_toolBars;
|
||||||
|
|
||||||
DebuggerLanguages m_supportedLanguages;
|
DebuggerLanguages m_supportedLanguages;
|
||||||
int m_languageCount;
|
|
||||||
|
|
||||||
QStackedWidget *m_toolbarStack;
|
QStackedWidget *m_toolbarStack;
|
||||||
|
|
||||||
@@ -161,16 +142,19 @@ public:
|
|||||||
|
|
||||||
DebuggerMainWindowPrivate::DebuggerMainWindowPrivate(DebuggerMainWindow *mw)
|
DebuggerMainWindowPrivate::DebuggerMainWindowPrivate(DebuggerMainWindow *mw)
|
||||||
: q(mw)
|
: q(mw)
|
||||||
, m_resizeEventFilter(new Internal::DockWidgetEventFilter(mw))
|
, m_resizeEventFilter(this)
|
||||||
, m_supportedLanguages(AnyLanguage)
|
, m_supportedLanguages(AnyLanguage)
|
||||||
, m_languageCount(0)
|
|
||||||
, m_toolbarStack(new QStackedWidget)
|
, m_toolbarStack(new QStackedWidget)
|
||||||
, m_inDebugMode(false)
|
, m_inDebugMode(false)
|
||||||
, m_changingUI(false)
|
, m_changingUI(false)
|
||||||
, m_previousDebugLanguages(AnyLanguage)
|
, m_previousDebugLanguages(AnyLanguage)
|
||||||
, m_activeDebugLanguages(AnyLanguage)
|
, m_activeDebugLanguages(AnyLanguage)
|
||||||
, m_viewsMenu(0)
|
, m_viewsMenu(0)
|
||||||
{}
|
{
|
||||||
|
createViewsMenuItems();
|
||||||
|
addLanguage(CppLanguage, Context(C_CPPDEBUGGER));
|
||||||
|
addLanguage(QmlLanguage, Context(C_QMLDEBUGGER));
|
||||||
|
}
|
||||||
|
|
||||||
void DebuggerMainWindowPrivate::updateUiOnFileListChange()
|
void DebuggerMainWindowPrivate::updateUiOnFileListChange()
|
||||||
{
|
{
|
||||||
@@ -229,7 +213,38 @@ void DebuggerMainWindowPrivate::updateUiForRunConfiguration(RunConfiguration *rc
|
|||||||
|
|
||||||
void DebuggerMainWindowPrivate::updateUiForCurrentRunConfiguration()
|
void DebuggerMainWindowPrivate::updateUiForCurrentRunConfiguration()
|
||||||
{
|
{
|
||||||
q->updateActiveLanguages();
|
updateActiveLanguages();
|
||||||
|
}
|
||||||
|
|
||||||
|
void DebuggerMainWindowPrivate::updateActiveLanguages()
|
||||||
|
{
|
||||||
|
DebuggerLanguages newLanguages = AnyLanguage;
|
||||||
|
|
||||||
|
if (m_previousRunConfiguration) {
|
||||||
|
if (m_previousRunConfiguration.data()->useCppDebugger())
|
||||||
|
newLanguages = CppLanguage;
|
||||||
|
if (m_previousRunConfiguration.data()->useQmlDebugger())
|
||||||
|
newLanguages |= QmlLanguage;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (newLanguages != m_activeDebugLanguages) {
|
||||||
|
m_activeDebugLanguages = newLanguages;
|
||||||
|
debuggerCore()->languagesChanged();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_changingUI || !m_inDebugMode)
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_changingUI = true;
|
||||||
|
|
||||||
|
if (isQmlActive())
|
||||||
|
activateQmlCppLayout();
|
||||||
|
else
|
||||||
|
activateCppLayout();
|
||||||
|
|
||||||
|
m_previousDebugLanguages = m_activeDebugLanguages;
|
||||||
|
|
||||||
|
m_changingUI = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
@@ -239,9 +254,6 @@ using namespace Internal;
|
|||||||
DebuggerMainWindow::DebuggerMainWindow()
|
DebuggerMainWindow::DebuggerMainWindow()
|
||||||
{
|
{
|
||||||
d = new DebuggerMainWindowPrivate(this);
|
d = new DebuggerMainWindowPrivate(this);
|
||||||
d->createViewsMenuItems();
|
|
||||||
d->addLanguage(CppLanguage, Context(C_CPPDEBUGGER));
|
|
||||||
d->addLanguage(QmlLanguage, Context(C_QMLDEBUGGER));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DebuggerMainWindow::~DebuggerMainWindow()
|
DebuggerMainWindow::~DebuggerMainWindow()
|
||||||
@@ -249,25 +261,6 @@ DebuggerMainWindow::~DebuggerMainWindow()
|
|||||||
delete d;
|
delete d;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DebuggerMainWindow::updateActiveLanguages()
|
|
||||||
{
|
|
||||||
DebuggerLanguages newLanguages = AnyLanguage;
|
|
||||||
|
|
||||||
if (d->m_previousRunConfiguration) {
|
|
||||||
if (d->m_previousRunConfiguration.data()->useCppDebugger())
|
|
||||||
newLanguages = CppLanguage;
|
|
||||||
if (d->m_previousRunConfiguration.data()->useQmlDebugger())
|
|
||||||
newLanguages |= QmlLanguage;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (newLanguages != d->m_activeDebugLanguages) {
|
|
||||||
d->m_activeDebugLanguages = newLanguages;
|
|
||||||
emit activeLanguagesChanged(d->m_activeDebugLanguages);
|
|
||||||
}
|
|
||||||
|
|
||||||
d->updateUi();
|
|
||||||
}
|
|
||||||
|
|
||||||
DebuggerLanguages DebuggerMainWindow::activeDebugLanguages() const
|
DebuggerLanguages DebuggerMainWindow::activeDebugLanguages() const
|
||||||
{
|
{
|
||||||
return d->m_activeDebugLanguages;
|
return d->m_activeDebugLanguages;
|
||||||
@@ -277,25 +270,18 @@ void DebuggerMainWindow::onModeChanged(IMode *mode)
|
|||||||
{
|
{
|
||||||
d->m_inDebugMode = (mode->id() == Constants::MODE_DEBUG);
|
d->m_inDebugMode = (mode->id() == Constants::MODE_DEBUG);
|
||||||
setDockActionsVisible(d->m_inDebugMode);
|
setDockActionsVisible(d->m_inDebugMode);
|
||||||
d->hideInactiveWidgets();
|
|
||||||
|
|
||||||
if (mode->id() != Constants::MODE_DEBUG)
|
|
||||||
return;
|
|
||||||
|
|
||||||
readSettings();
|
|
||||||
updateActiveLanguages();
|
|
||||||
}
|
|
||||||
|
|
||||||
void DebuggerMainWindowPrivate::hideInactiveWidgets()
|
|
||||||
{
|
|
||||||
// Hide all the debugger windows if mode is different.
|
// Hide all the debugger windows if mode is different.
|
||||||
if (m_inDebugMode)
|
if (mode->id() == Constants::MODE_DEBUG) {
|
||||||
return;
|
readSettings();
|
||||||
|
d->updateActiveLanguages();
|
||||||
|
} else {
|
||||||
// Hide dock widgets manually in case they are floating.
|
// Hide dock widgets manually in case they are floating.
|
||||||
foreach (QDockWidget *dockWidget, m_dockWidgets) {
|
foreach (QDockWidget *dockWidget, d->m_dockWidgets) {
|
||||||
if (dockWidget->isFloating())
|
if (dockWidget->isFloating())
|
||||||
dockWidget->hide();
|
dockWidget->hide();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void DebuggerMainWindowPrivate::createViewsMenuItems()
|
void DebuggerMainWindowPrivate::createViewsMenuItems()
|
||||||
@@ -309,7 +295,7 @@ void DebuggerMainWindowPrivate::createViewsMenuItems()
|
|||||||
QAction *openMemoryEditorAction = new QAction(this);
|
QAction *openMemoryEditorAction = new QAction(this);
|
||||||
openMemoryEditorAction->setText(tr("Memory..."));
|
openMemoryEditorAction->setText(tr("Memory..."));
|
||||||
connect(openMemoryEditorAction, SIGNAL(triggered()),
|
connect(openMemoryEditorAction, SIGNAL(triggered()),
|
||||||
q, SIGNAL(memoryEditorRequested()));
|
SLOT(openMemoryEditor()));
|
||||||
|
|
||||||
// Add menu items
|
// Add menu items
|
||||||
Command *cmd = 0;
|
Command *cmd = 0;
|
||||||
@@ -335,29 +321,10 @@ void DebuggerMainWindowPrivate::addLanguage(const DebuggerLanguage &languageId,
|
|||||||
const Context &context)
|
const Context &context)
|
||||||
{
|
{
|
||||||
m_supportedLanguages = m_supportedLanguages | languageId;
|
m_supportedLanguages = m_supportedLanguages | languageId;
|
||||||
m_languageCount++;
|
|
||||||
|
|
||||||
m_toolBars.insert(languageId, 0);
|
m_toolBars.insert(languageId, 0);
|
||||||
m_contextsForLanguage.insert(languageId, context);
|
m_contextsForLanguage.insert(languageId, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DebuggerMainWindowPrivate::updateUi()
|
|
||||||
{
|
|
||||||
if (m_changingUI || !m_inDebugMode)
|
|
||||||
return;
|
|
||||||
|
|
||||||
m_changingUI = true;
|
|
||||||
|
|
||||||
if (isQmlActive())
|
|
||||||
activateQmlCppLayout();
|
|
||||||
else
|
|
||||||
activateCppLayout();
|
|
||||||
|
|
||||||
m_previousDebugLanguages = m_activeDebugLanguages;
|
|
||||||
|
|
||||||
m_changingUI = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DebuggerMainWindowPrivate::activateQmlCppLayout()
|
void DebuggerMainWindowPrivate::activateQmlCppLayout()
|
||||||
{
|
{
|
||||||
ICore *core = ICore::instance();
|
ICore *core = ICore::instance();
|
||||||
@@ -449,14 +416,14 @@ QDockWidget *DebuggerMainWindow::createDockWidget(const DebuggerLanguage &langua
|
|||||||
cmd->setAttribute(Command::CA_Hide);
|
cmd->setAttribute(Command::CA_Hide);
|
||||||
d->m_viewsMenu->addAction(cmd);
|
d->m_viewsMenu->addAction(cmd);
|
||||||
|
|
||||||
dockWidget->installEventFilter(d->m_resizeEventFilter);
|
dockWidget->installEventFilter(&d->m_resizeEventFilter);
|
||||||
|
|
||||||
connect(dockWidget->toggleViewAction(), SIGNAL(triggered(bool)),
|
connect(dockWidget->toggleViewAction(), SIGNAL(triggered(bool)),
|
||||||
SLOT(updateDockWidgetSettings()));
|
d, SLOT(updateDockWidgetSettings()));
|
||||||
connect(dockWidget, SIGNAL(topLevelChanged(bool)),
|
connect(dockWidget, SIGNAL(topLevelChanged(bool)),
|
||||||
SLOT(updateDockWidgetSettings()));
|
d, SLOT(updateDockWidgetSettings()));
|
||||||
connect(dockWidget, SIGNAL(dockLocationChanged(Qt::DockWidgetArea)),
|
connect(dockWidget, SIGNAL(dockLocationChanged(Qt::DockWidgetArea)),
|
||||||
SLOT(updateDockWidgetSettings()));
|
d, SLOT(updateDockWidgetSettings()));
|
||||||
|
|
||||||
return dockWidget;
|
return dockWidget;
|
||||||
}
|
}
|
||||||
@@ -468,8 +435,6 @@ QWidget *DebuggerMainWindow::createContents(IMode *mode)
|
|||||||
ProjectExplorerPlugin *pe = ProjectExplorerPlugin::instance();
|
ProjectExplorerPlugin *pe = ProjectExplorerPlugin::instance();
|
||||||
connect(pe->session(), SIGNAL(startupProjectChanged(ProjectExplorer::Project*)),
|
connect(pe->session(), SIGNAL(startupProjectChanged(ProjectExplorer::Project*)),
|
||||||
d, SLOT(updateUiForProject(ProjectExplorer::Project*)));
|
d, SLOT(updateUiForProject(ProjectExplorer::Project*)));
|
||||||
connect(d->m_resizeEventFilter, SIGNAL(widgetResized()),
|
|
||||||
SLOT(updateDockWidgetSettings()));
|
|
||||||
|
|
||||||
d->m_viewsMenu = am->actionContainer(Core::Id(Core::Constants::M_WINDOW_VIEWS));
|
d->m_viewsMenu = am->actionContainer(Core::Id(Core::Constants::M_WINDOW_VIEWS));
|
||||||
QTC_ASSERT(d->m_viewsMenu, return 0)
|
QTC_ASSERT(d->m_viewsMenu, return 0)
|
||||||
@@ -480,7 +445,7 @@ QWidget *DebuggerMainWindow::createContents(IMode *mode)
|
|||||||
connect(this, SIGNAL(resetLayout()),
|
connect(this, SIGNAL(resetLayout()),
|
||||||
d, SLOT(resetDebuggerLayout()));
|
d, SLOT(resetDebuggerLayout()));
|
||||||
connect(toggleLockedAction(), SIGNAL(triggered()),
|
connect(toggleLockedAction(), SIGNAL(triggered()),
|
||||||
SLOT(updateDockWidgetSettings()));
|
d, SLOT(updateDockWidgetSettings()));
|
||||||
|
|
||||||
QBoxLayout *editorHolderLayout = new QVBoxLayout;
|
QBoxLayout *editorHolderLayout = new QVBoxLayout;
|
||||||
editorHolderLayout->setMargin(0);
|
editorHolderLayout->setMargin(0);
|
||||||
@@ -615,18 +580,18 @@ void DebuggerMainWindowPrivate::resetDebuggerLayout()
|
|||||||
else
|
else
|
||||||
m_dockWidgetActiveStateCpp = q->saveSettings();
|
m_dockWidgetActiveStateCpp = q->saveSettings();
|
||||||
|
|
||||||
q->updateActiveLanguages();
|
updateActiveLanguages();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DebuggerMainWindow::updateDockWidgetSettings()
|
void DebuggerMainWindowPrivate::updateDockWidgetSettings()
|
||||||
{
|
{
|
||||||
if (!d->m_inDebugMode || d->m_changingUI)
|
if (!m_inDebugMode || m_changingUI)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (d->isQmlActive())
|
if (isQmlActive())
|
||||||
d->m_dockWidgetActiveStateQmlCpp = saveSettings();
|
m_dockWidgetActiveStateQmlCpp = q->saveSettings();
|
||||||
else
|
else
|
||||||
d->m_dockWidgetActiveStateCpp = saveSettings();
|
m_dockWidgetActiveStateCpp = q->saveSettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DebuggerMainWindowPrivate::isQmlCppActive() const
|
bool DebuggerMainWindowPrivate::isQmlCppActive() const
|
||||||
@@ -748,6 +713,19 @@ void DebuggerMainWindowPrivate::setSimpleDockWidgetArrangement()
|
|||||||
q->update();
|
q->update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool DockWidgetEventFilter::eventFilter(QObject *obj, QEvent *event)
|
||||||
|
{
|
||||||
|
switch (event->type()) {
|
||||||
|
case QEvent::Resize:
|
||||||
|
case QEvent::ZOrderChange:
|
||||||
|
m_mw->updateDockWidgetSettings();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return QObject::eventFilter(obj, event);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Debugger
|
} // namespace Debugger
|
||||||
|
|
||||||
#include "debuggermainwindow.moc"
|
#include "debuggermainwindow.moc"
|
||||||
|
|||||||
@@ -55,8 +55,6 @@ class DebuggerMainWindowPrivate;
|
|||||||
|
|
||||||
class DEBUGGER_EXPORT DebuggerMainWindow : public Utils::FancyMainWindow
|
class DEBUGGER_EXPORT DebuggerMainWindow : public Utils::FancyMainWindow
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
DebuggerMainWindow();
|
DebuggerMainWindow();
|
||||||
~DebuggerMainWindow();
|
~DebuggerMainWindow();
|
||||||
@@ -80,15 +78,6 @@ public:
|
|||||||
QWidget *createContents(Core::IMode *mode);
|
QWidget *createContents(Core::IMode *mode);
|
||||||
QMenu *createPopupMenu();
|
QMenu *createPopupMenu();
|
||||||
|
|
||||||
signals:
|
|
||||||
// Emit when user changes active languages from the menu.
|
|
||||||
// Both UI and debugger startup are affected.
|
|
||||||
void activeLanguagesChanged(Debugger::DebuggerLanguages activeLanguages);
|
|
||||||
void memoryEditorRequested();
|
|
||||||
|
|
||||||
public slots:
|
|
||||||
void updateActiveLanguages();
|
|
||||||
void updateDockWidgetSettings();
|
|
||||||
void readSettings();
|
void readSettings();
|
||||||
void writeSettings() const;
|
void writeSettings() const;
|
||||||
|
|
||||||
|
|||||||
@@ -1024,7 +1024,7 @@ public slots:
|
|||||||
void attachRemoteTcf();
|
void attachRemoteTcf();
|
||||||
|
|
||||||
void enableReverseDebuggingTriggered(const QVariant &value);
|
void enableReverseDebuggingTriggered(const QVariant &value);
|
||||||
void languagesChanged(const Debugger::DebuggerLanguages &languages);
|
void languagesChanged();
|
||||||
void showStatusMessage(const QString &msg, int timeout = -1);
|
void showStatusMessage(const QString &msg, int timeout = -1);
|
||||||
void openMemoryEditor();
|
void openMemoryEditor();
|
||||||
|
|
||||||
@@ -1495,11 +1495,11 @@ void DebuggerPluginPrivate::onCurrentProjectChanged(Project *project)
|
|||||||
core->updateAdditionalContexts(m_anyContext, Context());
|
core->updateAdditionalContexts(m_anyContext, Context());
|
||||||
}
|
}
|
||||||
|
|
||||||
void DebuggerPluginPrivate::languagesChanged(const DebuggerLanguages &languages)
|
void DebuggerPluginPrivate::languagesChanged()
|
||||||
{
|
{
|
||||||
const bool debuggerIsCPP = (languages & CppLanguage);
|
const bool debuggerIsCPP =
|
||||||
|
m_mainWindow->activeDebugLanguages() & CppLanguage;
|
||||||
//qDebug() << "DEBUGGER IS CPP: " << debuggerIsCPP;
|
//qDebug() << "DEBUGGER IS CPP: " << debuggerIsCPP;
|
||||||
|
|
||||||
m_startExternalAction->setVisible(debuggerIsCPP);
|
m_startExternalAction->setVisible(debuggerIsCPP);
|
||||||
m_attachExternalAction->setVisible(debuggerIsCPP);
|
m_attachExternalAction->setVisible(debuggerIsCPP);
|
||||||
m_attachCoreAction->setVisible(debuggerIsCPP);
|
m_attachCoreAction->setVisible(debuggerIsCPP);
|
||||||
@@ -2568,17 +2568,12 @@ void DebuggerPluginPrivate::createNewDock(QWidget *widget)
|
|||||||
m_mainWindow->createDockWidget(CppLanguage, widget);
|
m_mainWindow->createDockWidget(CppLanguage, widget);
|
||||||
dockWidget->setWindowTitle(widget->windowTitle());
|
dockWidget->setWindowTitle(widget->windowTitle());
|
||||||
dockWidget->setFeatures(QDockWidget::DockWidgetClosable);
|
dockWidget->setFeatures(QDockWidget::DockWidgetClosable);
|
||||||
//dockWidget->setWidget(widget);
|
|
||||||
//mainWindow()->addDockWidget(Qt::TopDockWidgetArea, dockWidget);
|
|
||||||
dockWidget->show();
|
dockWidget->show();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DebuggerPluginPrivate::runControlStarted(DebuggerRunControl *runControl)
|
void DebuggerPluginPrivate::runControlStarted(DebuggerRunControl *runControl)
|
||||||
{
|
{
|
||||||
activateDebugMode();
|
activateDebugMode();
|
||||||
if (!hasSnapshots())
|
|
||||||
m_mainWindow->updateActiveLanguages();
|
|
||||||
|
|
||||||
const QString message = runControl->idString();
|
const QString message = runControl->idString();
|
||||||
showMessage(message, StatusBar);
|
showMessage(message, StatusBar);
|
||||||
showMessage(m_debuggerSettings->dump(), LogDebug);
|
showMessage(m_debuggerSettings->dump(), LogDebug);
|
||||||
@@ -2855,8 +2850,6 @@ void DebuggerPluginPrivate::extensionsInitialized()
|
|||||||
dock = m_mainWindow->createDockWidget(CppLanguage, localsAndWatchers);
|
dock = m_mainWindow->createDockWidget(CppLanguage, localsAndWatchers);
|
||||||
dock->setProperty(DOCKWIDGET_DEFAULT_AREA, Qt::RightDockWidgetArea);
|
dock->setProperty(DOCKWIDGET_DEFAULT_AREA, Qt::RightDockWidgetArea);
|
||||||
|
|
||||||
//m_mainWindow->readSettings();
|
|
||||||
|
|
||||||
m_debuggerSettings->readSettings();
|
m_debuggerSettings->readSettings();
|
||||||
GdbOptionsPage::readGdbBinarySettings();
|
GdbOptionsPage::readGdbBinarySettings();
|
||||||
|
|
||||||
@@ -3188,11 +3181,6 @@ void DebuggerPluginPrivate::extensionsInitialized()
|
|||||||
SIGNAL(valueChanged(QVariant)),
|
SIGNAL(valueChanged(QVariant)),
|
||||||
SLOT(enableReverseDebuggingTriggered(QVariant)));
|
SLOT(enableReverseDebuggingTriggered(QVariant)));
|
||||||
|
|
||||||
// UI Switcher
|
|
||||||
connect(m_mainWindow,
|
|
||||||
SIGNAL(activeLanguagesChanged(Debugger::DebuggerLanguages)),
|
|
||||||
SLOT(languagesChanged(Debugger::DebuggerLanguages)));
|
|
||||||
|
|
||||||
setInitialState();
|
setInitialState();
|
||||||
connectEngine(0);
|
connectEngine(0);
|
||||||
|
|
||||||
@@ -3207,8 +3195,6 @@ void DebuggerPluginPrivate::extensionsInitialized()
|
|||||||
QTC_ASSERT(m_coreSettings, /**/);
|
QTC_ASSERT(m_coreSettings, /**/);
|
||||||
m_watchersWindow->setVisible(false);
|
m_watchersWindow->setVisible(false);
|
||||||
m_returnWindow->setVisible(false);
|
m_returnWindow->setVisible(false);
|
||||||
connect(m_mainWindow, SIGNAL(memoryEditorRequested()),
|
|
||||||
SLOT(openMemoryEditor()));
|
|
||||||
|
|
||||||
// time gdb -i mi -ex 'debuggerplugin.cpp:800' -ex r -ex q bin/qtcreator.bin
|
// time gdb -i mi -ex 'debuggerplugin.cpp:800' -ex r -ex q bin/qtcreator.bin
|
||||||
const QByteArray env = qgetenv("QTC_DEBUGGER_TEST");
|
const QByteArray env = qgetenv("QTC_DEBUGGER_TEST");
|
||||||
|
|||||||
Reference in New Issue
Block a user