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:
hjk
2010-12-06 11:06:18 +01:00
parent d6d830f593
commit 48c2dccd75
4 changed files with 86 additions and 131 deletions

View File

@@ -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;

View File

@@ -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,26 +270,19 @@ 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"

View File

@@ -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;

View File

@@ -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");