summaryrefslogtreecommitdiff
path: root/src/plugins/coreplugin/designmode.cpp
diff options
context:
space:
mode:
authorFriedemann Kleint <Friedemann.Kleint@nokia.com>2010-03-17 17:44:46 +0100
committerFriedemann Kleint <Friedemann.Kleint@nokia.com>2010-03-17 17:44:46 +0100
commit5cf8673ce179537e4c764cb2fd1d6057ceadff06 (patch)
treea8f18a3a7bb350b5c5caa6b3af1064cb73e7d401 /src/plugins/coreplugin/designmode.cpp
parent1e4ce5ee9f142c409bcf8f796ab013085e927149 (diff)
downloadqt-creator-5cf8673ce179537e4c764cb2fd1d6057ceadff06.tar.gz
Header cleanup in utils/coreplugin.
Diffstat (limited to 'src/plugins/coreplugin/designmode.cpp')
-rw-r--r--src/plugins/coreplugin/designmode.cpp94
1 files changed, 64 insertions, 30 deletions
diff --git a/src/plugins/coreplugin/designmode.cpp b/src/plugins/coreplugin/designmode.cpp
index c4aff16b61..fbabebb959 100644
--- a/src/plugins/coreplugin/designmode.cpp
+++ b/src/plugins/coreplugin/designmode.cpp
@@ -38,17 +38,19 @@
#include <coreplugin/actionmanager/command.h>
#include <coreplugin/coreconstants.h>
#include <coreplugin/mimedatabase.h>
+#include <coreplugin/icorelistener.h>
+#include <coreplugin/editormanager/ieditor.h>
#include <extensionsystem/pluginmanager.h>
#include <QtCore/QPair>
#include <QtCore/QFileInfo>
-#include <QtGui/QAction>
+#include <QtCore/QStringList>
+#include <QtCore/QDebug>
+#include <QtGui/QAction>
#include <QtGui/QPlainTextEdit>
#include <QtGui/QStackedWidget>
-#include <QtCore/QDebug>
-
namespace Core {
class EditorManager;
@@ -59,6 +61,15 @@ enum {
namespace Internal {
+class DesignModeCoreListener : public Core::ICoreListener
+{
+public:
+ DesignModeCoreListener(DesignMode* mode);
+ bool coreAboutToClose();
+private:
+ DesignMode *m_mode;
+};
+
DesignModeCoreListener::DesignModeCoreListener(DesignMode *mode) :
m_mode(mode)
{
@@ -72,27 +83,50 @@ bool DesignModeCoreListener::coreAboutToClose()
} // namespace Internal
+struct DesignEditorInfo {
+ int widgetIndex;
+ QStringList mimeTypes;
+ bool preferredMode;
+ QWidget *widget;
+};
+
+struct DesignModePrivate {
+ explicit DesignModePrivate(DesignMode *q, EditorManager *editorManager);
+ Internal::DesignModeCoreListener *m_coreListener;
+ QWeakPointer<Core::IEditor> m_currentEditor;
+ bool m_isActive;
+
+ QList<DesignEditorInfo*> m_editors;
+
+ EditorManager *m_editorManager;
+ QStackedWidget *m_stackWidget;
+};
+
+DesignModePrivate::DesignModePrivate(DesignMode *q, EditorManager *editorManager) :
+ m_coreListener(new Internal::DesignModeCoreListener(q)),
+ m_isActive(false),
+ m_editorManager(editorManager),
+ m_stackWidget(new QStackedWidget)
+{
+}
+
DesignMode::DesignMode(EditorManager *editorManager) :
- IMode(),
- m_coreListener(new Internal::DesignModeCoreListener(this)),
- m_isActive(false),
- m_editorManager(editorManager),
- m_stackWidget(new QStackedWidget)
+ IMode(), d(new DesignModePrivate(this, editorManager))
{
setEnabled(false);
- ExtensionSystem::PluginManager::instance()->addObject(m_coreListener);
+ ExtensionSystem::PluginManager::instance()->addObject(d->m_coreListener);
connect(editorManager, SIGNAL(currentEditorChanged(Core::IEditor*)),
this, SLOT(currentEditorChanged(Core::IEditor*)));
- //updateActions();
}
DesignMode::~DesignMode()
{
- ExtensionSystem::PluginManager::instance()->removeObject(m_coreListener);
- delete m_coreListener;
+ ExtensionSystem::PluginManager::instance()->removeObject(d->m_coreListener);
+ delete d->m_coreListener;
- qDeleteAll(m_editors);
+ qDeleteAll(d->m_editors);
+ delete d;
}
QList<int> DesignMode::context() const
@@ -104,7 +138,7 @@ QList<int> DesignMode::context() const
QWidget *DesignMode::widget()
{
- return m_stackWidget;
+ return d->m_stackWidget;
}
QString DesignMode::displayName() const
@@ -130,29 +164,29 @@ QString DesignMode::id() const
QStringList DesignMode::registeredMimeTypes() const
{
QStringList rc;
- foreach(const DesignEditorInfo *i, m_editors)
+ foreach(const DesignEditorInfo *i, d->m_editors)
rc += i->mimeTypes;
return rc;
}
void DesignMode::registerDesignWidget(QWidget *widget, const QStringList &mimeTypes, bool preferDesignMode)
{
- int index = m_stackWidget->addWidget(widget);
+ int index = d->m_stackWidget->addWidget(widget);
DesignEditorInfo *info = new DesignEditorInfo;
info->preferredMode = preferDesignMode;
info->mimeTypes = mimeTypes;
info->widgetIndex = index;
info->widget = widget;
- m_editors.append(info);
+ d->m_editors.append(info);
}
void DesignMode::unregisterDesignWidget(QWidget *widget)
{
- m_stackWidget->removeWidget(widget);
- foreach(DesignEditorInfo *info, m_editors) {
+ d->m_stackWidget->removeWidget(widget);
+ foreach(DesignEditorInfo *info, d->m_editors) {
if (info->widget == widget) {
- m_editors.removeAll(info);
+ d->m_editors.removeAll(info);
break;
}
}
@@ -174,10 +208,10 @@ void DesignMode::currentEditorChanged(Core::IEditor *editor)
- foreach(DesignEditorInfo *editorInfo, m_editors) {
+ foreach(DesignEditorInfo *editorInfo, d->m_editors) {
foreach(QString mime, editorInfo->mimeTypes) {
if (mime == mimeType) {
- m_stackWidget->setCurrentIndex(editorInfo->widgetIndex);
+ d->m_stackWidget->setCurrentIndex(editorInfo->widgetIndex);
mimeEditorAvailable = true;
setEnabled(true);
if (editorInfo->preferredMode && core->modeManager()->currentMode() != this) {
@@ -200,23 +234,23 @@ void DesignMode::currentEditorChanged(Core::IEditor *editor)
core->modeManager()->activateMode(Constants::MODE_EDIT);
}
- if (m_currentEditor.data() == editor)
+ if (d->m_currentEditor.data() == editor)
return;
- if (m_currentEditor)
- disconnect(m_currentEditor.data(), SIGNAL(changed()), this, SLOT(updateActions()));
+ if (d->m_currentEditor)
+ disconnect(d->m_currentEditor.data(), SIGNAL(changed()), this, SLOT(updateActions()));
- m_currentEditor = QWeakPointer<Core::IEditor>(editor);
+ d->m_currentEditor = QWeakPointer<Core::IEditor>(editor);
- if (m_currentEditor)
- connect(m_currentEditor.data(), SIGNAL(changed()), this, SLOT(updateActions()));
+ if (d->m_currentEditor)
+ connect(d->m_currentEditor.data(), SIGNAL(changed()), this, SLOT(updateActions()));
- emit actionsUpdated(m_currentEditor.data());
+ emit actionsUpdated(d->m_currentEditor.data());
}
void DesignMode::updateActions()
{
- emit actionsUpdated(m_currentEditor.data());
+ emit actionsUpdated(d->m_currentEditor.data());
}
} // namespace Core