aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/todo
diff options
context:
space:
mode:
authorhjk <hjk@qt.io>2020-02-07 17:50:21 +0100
committerhjk <hjk@qt.io>2020-02-10 08:03:53 +0000
commit9a42382fd15fd9d2f5a94737f6d496478a6bf096 (patch)
tree2646b8985b8229a420614606e3f732805109cc3c /src/plugins/todo
parent8228d43579c41ae78dabdf03c0422601661b75fa (diff)
Todo: Pimpl plugin and move OptionPage to new scheme
Change-Id: I75409ff14697f0edf505328e19483a4dda8f6062 Reviewed-by: Orgad Shaneh <orgads@gmail.com>
Diffstat (limited to 'src/plugins/todo')
-rw-r--r--src/plugins/todo/CMakeLists.txt1
-rw-r--r--src/plugins/todo/optionsdialog.cpp136
-rw-r--r--src/plugins/todo/optionsdialog.h32
-rw-r--r--src/plugins/todo/optionspage.cpp88
-rw-r--r--src/plugins/todo/optionspage.h62
-rw-r--r--src/plugins/todo/todo.pro2
-rw-r--r--src/plugins/todo/todo.qbs2
-rw-r--r--src/plugins/todo/todoplugin.cpp67
-rw-r--r--src/plugins/todo/todoplugin.h25
9 files changed, 134 insertions, 281 deletions
diff --git a/src/plugins/todo/CMakeLists.txt b/src/plugins/todo/CMakeLists.txt
index 893e43a550c..4d24e7b90b3 100644
--- a/src/plugins/todo/CMakeLists.txt
+++ b/src/plugins/todo/CMakeLists.txt
@@ -8,7 +8,6 @@ add_qtc_plugin(Todo
keyworddialog.cpp keyworddialog.h keyworddialog.ui
lineparser.cpp lineparser.h
optionsdialog.cpp optionsdialog.h optionsdialog.ui
- optionspage.cpp optionspage.h
qmljstodoitemsscanner.cpp qmljstodoitemsscanner.h
settings.cpp settings.h
todoicons.cpp todoicons.h
diff --git a/src/plugins/todo/optionsdialog.cpp b/src/plugins/todo/optionsdialog.cpp
index e06e90c9fef..dc4f2d1d940 100644
--- a/src/plugins/todo/optionsdialog.cpp
+++ b/src/plugins/todo/optionsdialog.cpp
@@ -34,66 +34,74 @@
namespace Todo {
namespace Internal {
-OptionsDialog::OptionsDialog() :
- ui(new Ui::OptionsDialog)
+class OptionsDialog final : public Core::IOptionsPageWidget
{
- ui->setupUi(this);
- ui->keywordsList->setIconSize(QSize(16, 16));
+ Q_DECLARE_TR_FUNCTIONS(Todo::Internal::TodoOptionsPage)
+
+public:
+ OptionsDialog(Settings *settings, const std::function<void ()> &onApply);
+
+ void apply() final;
+
+ void setSettings(const Settings &settings);
+
+private:
+ void addKeywordButtonClicked();
+ void editKeywordButtonClicked();
+ void removeKeywordButtonClicked();
+ void resetKeywordsButtonClicked();
+ void setKeywordsButtonsEnabled();
+ Settings settingsFromUi();
+ void addToKeywordsList(const Keyword &keyword);
+ void editKeyword(QListWidgetItem *item);
+ QSet<QString> keywordNames();
+
+ Ui::OptionsDialog ui;
+ Settings *m_settings = nullptr;
+ std::function<void()> m_onApply;
+};
+
+OptionsDialog::OptionsDialog(Settings *settings, const std::function<void ()> &onApply)
+ : m_settings(settings), m_onApply(onApply)
+{
+ ui.setupUi(this);
+ ui.keywordsList->setIconSize(QSize(16, 16));
setKeywordsButtonsEnabled();
- connect(ui->addKeywordButton, &QAbstractButton::clicked,
+ connect(ui.addKeywordButton, &QAbstractButton::clicked,
this, &OptionsDialog::addKeywordButtonClicked);
- connect(ui->removeKeywordButton, &QAbstractButton::clicked,
+ connect(ui.removeKeywordButton, &QAbstractButton::clicked,
this, &OptionsDialog::removeKeywordButtonClicked);
- connect(ui->editKeywordButton, &QAbstractButton::clicked,
+ connect(ui.editKeywordButton, &QAbstractButton::clicked,
this, &OptionsDialog::editKeywordButtonClicked);
- connect(ui->resetKeywordsButton, &QAbstractButton::clicked,
+ connect(ui.resetKeywordsButton, &QAbstractButton::clicked,
this, &OptionsDialog::resetKeywordsButtonClicked);
- connect(ui->keywordsList, &QListWidget::itemDoubleClicked,
- this, &OptionsDialog::keywordDoubleClicked);
- connect(ui->keywordsList, &QListWidget::itemSelectionChanged,
+ connect(ui.keywordsList, &QListWidget::itemDoubleClicked,
+ this, &OptionsDialog::editKeyword);
+ connect(ui.keywordsList, &QListWidget::itemSelectionChanged,
this, &OptionsDialog::setKeywordsButtonsEnabled);
-}
-OptionsDialog::~OptionsDialog()
-{
- delete ui;
-}
-
-void OptionsDialog::keywordDoubleClicked(QListWidgetItem *item)
-{
- editKeyword(item);
-}
-
-void OptionsDialog::setSettings(const Settings &settings)
-{
- uiFromSettings(settings);
+ setSettings(*m_settings);
}
void OptionsDialog::addToKeywordsList(const Keyword &keyword)
{
- QListWidgetItem *item = new QListWidgetItem(
- icon(keyword.iconType), keyword.name);
+ auto item = new QListWidgetItem(icon(keyword.iconType), keyword.name);
item->setData(Qt::UserRole, static_cast<int>(keyword.iconType));
item->setForeground(keyword.color);
- ui->keywordsList->addItem(item);
+ ui.keywordsList->addItem(item);
}
QSet<QString> OptionsDialog::keywordNames()
{
- KeywordList keywords = settingsFromUi().keywords;
+ const KeywordList keywords = settingsFromUi().keywords;
QSet<QString> result;
- foreach (const Keyword &keyword, keywords)
+ for (const Keyword &keyword : keywords)
result << keyword.name;
return result;
}
-Settings OptionsDialog::settings()
-{
- return settingsFromUi();
-}
-
void OptionsDialog::addKeywordButtonClicked()
{
Keyword keyword;
@@ -106,7 +114,7 @@ void OptionsDialog::addKeywordButtonClicked()
void OptionsDialog::editKeywordButtonClicked()
{
- QListWidgetItem *item = ui->keywordsList->currentItem();
+ QListWidgetItem *item = ui.keywordsList->currentItem();
editKeyword(item);
}
@@ -132,31 +140,31 @@ void OptionsDialog::editKeyword(QListWidgetItem *item)
void OptionsDialog::removeKeywordButtonClicked()
{
- delete ui->keywordsList->takeItem(ui->keywordsList->currentRow());
+ delete ui.keywordsList->takeItem(ui.keywordsList->currentRow());
}
void OptionsDialog::resetKeywordsButtonClicked()
{
Settings newSettings;
newSettings.setDefault();
- uiFromSettings(newSettings);
+ setSettings(newSettings);
}
void OptionsDialog::setKeywordsButtonsEnabled()
{
- const bool isSomethingSelected = !ui->keywordsList->selectedItems().isEmpty();
- ui->removeKeywordButton->setEnabled(isSomethingSelected);
- ui->editKeywordButton->setEnabled(isSomethingSelected);
+ const bool isSomethingSelected = !ui.keywordsList->selectedItems().isEmpty();
+ ui.removeKeywordButton->setEnabled(isSomethingSelected);
+ ui.editKeywordButton->setEnabled(isSomethingSelected);
}
-void OptionsDialog::uiFromSettings(const Settings &settings)
+void OptionsDialog::setSettings(const Settings &settings)
{
- ui->scanInCurrentFileRadioButton->setChecked(settings.scanningScope == ScanningScopeCurrentFile);
- ui->scanInProjectRadioButton->setChecked(settings.scanningScope == ScanningScopeProject);
- ui->scanInSubprojectRadioButton->setChecked(settings.scanningScope == ScanningScopeSubProject);
+ ui.scanInCurrentFileRadioButton->setChecked(settings.scanningScope == ScanningScopeCurrentFile);
+ ui.scanInProjectRadioButton->setChecked(settings.scanningScope == ScanningScopeProject);
+ ui.scanInSubprojectRadioButton->setChecked(settings.scanningScope == ScanningScopeSubProject);
- ui->keywordsList->clear();
- foreach (const Keyword &keyword, settings.keywords)
+ ui.keywordsList->clear();
+ for (const Keyword &keyword : qAsConst(settings.keywords))
addToKeywordsList(keyword);
}
@@ -164,16 +172,16 @@ Settings OptionsDialog::settingsFromUi()
{
Settings settings;
- if (ui->scanInCurrentFileRadioButton->isChecked())
+ if (ui.scanInCurrentFileRadioButton->isChecked())
settings.scanningScope = ScanningScopeCurrentFile;
- else if (ui->scanInSubprojectRadioButton->isChecked())
+ else if (ui.scanInSubprojectRadioButton->isChecked())
settings.scanningScope = ScanningScopeSubProject;
else
settings.scanningScope = ScanningScopeProject;
settings.keywords.clear();
- for (int i = 0; i < ui->keywordsList->count(); ++i) {
- QListWidgetItem *item = ui->keywordsList->item(i);
+ for (int i = 0; i < ui.keywordsList->count(); ++i) {
+ QListWidgetItem *item = ui.keywordsList->item(i);
Keyword keyword;
keyword.name = item->text();
@@ -186,5 +194,31 @@ Settings OptionsDialog::settingsFromUi()
return settings;
}
+void OptionsDialog::apply()
+{
+ Settings newSettings = settingsFromUi();
+
+ // "apply" itself is interpreted as "use these keywords, also for other themes".
+ newSettings.keywordsEdited = true;
+
+ if (newSettings == *m_settings)
+ return;
+
+ *m_settings = newSettings;
+ m_onApply();
+}
+
+// TodoOptionsPage
+
+TodoOptionsPage::TodoOptionsPage(Settings *settings, const std::function<void ()> &onApply)
+{
+ setId("TodoSettings");
+ setDisplayName(OptionsDialog::tr("To-Do"));
+ setCategory("To-Do");
+ setDisplayCategory(OptionsDialog::tr("To-Do"));
+ setCategoryIconPath(":/todoplugin/images/settingscategory_todo.png");
+ setWidgetCreator([settings, onApply] { return new OptionsDialog(settings, onApply); });
+}
+
} // namespace Internal
} // namespace Todo
diff --git a/src/plugins/todo/optionsdialog.h b/src/plugins/todo/optionsdialog.h
index 7f48ff26162..39bedcb481b 100644
--- a/src/plugins/todo/optionsdialog.h
+++ b/src/plugins/todo/optionsdialog.h
@@ -26,43 +26,17 @@
#pragma once
-#include <QWidget>
-
-QT_BEGIN_NAMESPACE
-class QListWidgetItem;
-QT_END_NAMESPACE
+#include <coreplugin/dialogs/ioptionspage.h>
namespace Todo {
namespace Internal {
-namespace Ui { class OptionsDialog; }
-
class Settings;
-class Keyword;
-class OptionsDialog : public QWidget
+class TodoOptionsPage final : public Core::IOptionsPage
{
public:
- OptionsDialog();
- ~OptionsDialog() override;
-
- void setSettings(const Settings &settings);
- Settings settings();
-
-private:
- void addKeywordButtonClicked();
- void editKeywordButtonClicked();
- void removeKeywordButtonClicked();
- void resetKeywordsButtonClicked();
- void setKeywordsButtonsEnabled();
- void keywordDoubleClicked(QListWidgetItem *item);
- void uiFromSettings(const Settings &settings);
- Settings settingsFromUi();
- void addToKeywordsList(const Keyword &keyword);
- void editKeyword(QListWidgetItem *item);
- QSet<QString> keywordNames();
-
- Ui::OptionsDialog *ui;
+ TodoOptionsPage(Settings *settings, const std::function<void()> &onApply);
};
} // namespace Internal
diff --git a/src/plugins/todo/optionspage.cpp b/src/plugins/todo/optionspage.cpp
deleted file mode 100644
index 3a6e13de516..00000000000
--- a/src/plugins/todo/optionspage.cpp
+++ /dev/null
@@ -1,88 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 Dmitry Savchenko
-** Copyright (C) 2016 Vasiliy Sorokin
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of Qt Creator.
-**
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-****************************************************************************/
-
-#include "optionspage.h"
-#include "constants.h"
-#include "optionsdialog.h"
-
-#include <coreplugin/icore.h>
-
-#include <QList>
-#include <QIcon>
-#include <QMessageBox>
-
-Todo::Internal::OptionsDialog *some = nullptr;
-
-namespace Todo {
-namespace Internal {
-
-OptionsPage::OptionsPage(const Settings &settings, QObject *parent) :
- IOptionsPage(parent)
-{
- setSettings(settings);
-
- setId("TodoSettings");
- setDisplayName(tr("To-Do"));
- setCategory("To-Do");
- setDisplayCategory(tr("To-Do"));
- setCategoryIconPath(":/todoplugin/images/settingscategory_todo.png");
-}
-
-void OptionsPage::setSettings(const Settings &settings)
-{
- m_settings = settings;
-}
-
-QWidget *OptionsPage::widget()
-{
- if (!m_widget) {
- m_widget = new OptionsDialog;
- m_widget->setSettings(m_settings);
- }
- return m_widget;
-}
-
-void OptionsPage::apply()
-{
- Settings newSettings = m_widget->settings();
-
- // "apply" itself is interpreted as "use these keywords, also for other themes".
- newSettings.keywordsEdited = true;
-
- if (newSettings != m_settings) {
- m_settings = newSettings;
- emit settingsChanged(m_settings);
- }
-}
-
-void OptionsPage::finish()
-{
- delete m_widget;
-}
-
-} // namespace Internal
-} // namespace Todo
-
diff --git a/src/plugins/todo/optionspage.h b/src/plugins/todo/optionspage.h
deleted file mode 100644
index b546f8f6d39..00000000000
--- a/src/plugins/todo/optionspage.h
+++ /dev/null
@@ -1,62 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 Dmitry Savchenko
-** Copyright (C) 2016 Vasiliy Sorokin
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of Qt Creator.
-**
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-****************************************************************************/
-
-#pragma once
-
-#include "settings.h"
-
-#include <coreplugin/dialogs/ioptionspage.h>
-
-#include <QPointer>
-
-namespace Todo {
-namespace Internal {
-
-class OptionsDialog;
-
-class OptionsPage : public Core::IOptionsPage
-{
- Q_OBJECT
-
-public:
- OptionsPage(const Settings &settings, QObject *parent = nullptr);
-
- void setSettings(const Settings &settings);
-
- QWidget *widget() override;
- void apply() override;
- void finish() override;
-
-signals:
- void settingsChanged(const Settings &settings);
-
-private:
- QPointer<OptionsDialog> m_widget;
- Settings m_settings;
-};
-
-} // namespace Internal
-} // namespace Todo
diff --git a/src/plugins/todo/todo.pro b/src/plugins/todo/todo.pro
index 72714259594..ff150d4b6a5 100644
--- a/src/plugins/todo/todo.pro
+++ b/src/plugins/todo/todo.pro
@@ -6,7 +6,6 @@ HEADERS += todoplugin.h \
todooutputpane.h \
todoitem.h \
settings.h \
- optionspage.h \
optionsdialog.h\
keyworddialog.h \
todoitemsprovider.h \
@@ -23,7 +22,6 @@ HEADERS += todoplugin.h \
SOURCES += todoplugin.cpp \
keyword.cpp \
todooutputpane.cpp \
- optionspage.cpp \
settings.cpp \
optionsdialog.cpp \
keyworddialog.cpp \
diff --git a/src/plugins/todo/todo.qbs b/src/plugins/todo/todo.qbs
index 49d6d7f33e0..facb1a6a3c3 100644
--- a/src/plugins/todo/todo.qbs
+++ b/src/plugins/todo/todo.qbs
@@ -29,8 +29,6 @@ QtcPlugin {
"todoprojectsettingswidget.cpp",
"todoprojectsettingswidget.h",
"todoprojectsettingswidget.ui",
- "optionspage.cpp",
- "optionspage.h",
"qmljstodoitemsscanner.cpp",
"qmljstodoitemsscanner.h",
"settings.cpp",
diff --git a/src/plugins/todo/todoplugin.cpp b/src/plugins/todo/todoplugin.cpp
index 2a54f936eb6..fc7e47c6144 100644
--- a/src/plugins/todo/todoplugin.cpp
+++ b/src/plugins/todo/todoplugin.cpp
@@ -26,7 +26,7 @@
#include "todoplugin.h"
#include "constants.h"
-#include "optionspage.h"
+#include "optionsdialog.h"
#include "keyword.h"
#include "todooutputpane.h"
#include "todoitemsprovider.h"
@@ -38,28 +38,35 @@
#include <projectexplorer/projectpanelfactory.h>
-#include <QtPlugin>
#include <QFileInfo>
#include <QSettings>
namespace Todo {
namespace Internal {
-TodoPlugin::TodoPlugin()
+class TodoPluginPrivate : public QObject
{
- qRegisterMetaType<TodoItem>("TodoItem");
-}
+ Q_DECLARE_TR_FUNCTIONS(Todo::Internal::TodoPlugin)
-TodoPlugin::~TodoPlugin() = default;
+public:
+ TodoPluginPrivate();
-bool TodoPlugin::initialize(const QStringList& args, QString *errMsg)
-{
- Q_UNUSED(args)
- Q_UNUSED(errMsg)
+ void settingsChanged(const Settings &settings);
+ void scanningScopeChanged(ScanningScope scanningScope);
+ void todoItemClicked(const TodoItem &item);
+ void createItemsProvider();
+ void createTodoOutputPane();
+ Settings m_settings;
+ TodoOutputPane *m_todoOutputPane = nullptr;
+ TodoOptionsPage m_optionsPage{&m_settings, [this] { settingsChanged(m_settings); }};
+ TodoItemsProvider *m_todoItemsProvider = nullptr;
+};
+
+TodoPluginPrivate::TodoPluginPrivate()
+{
m_settings.load(Core::ICore::settings());
- createOptionsPage();
createItemsProvider();
createTodoOutputPane();
@@ -75,53 +82,63 @@ bool TodoPlugin::initialize(const QStringList& args, QString *errMsg)
ProjectExplorer::ProjectPanelFactory::registerFactory(panelFactory);
connect(Core::ICore::instance(), &Core::ICore::saveSettingsRequested,
this, [this] { m_settings.save(Core::ICore::settings()); });
-
- return true;
}
-void TodoPlugin::settingsChanged(const Settings &settings)
+void TodoPluginPrivate::settingsChanged(const Settings &settings)
{
settings.save(Core::ICore::settings());
m_settings = settings;
m_todoItemsProvider->settingsChanged(m_settings);
m_todoOutputPane->setScanningScope(m_settings.scanningScope);
- m_optionsPage->setSettings(m_settings);
}
-void TodoPlugin::scanningScopeChanged(ScanningScope scanningScope)
+void TodoPluginPrivate::scanningScopeChanged(ScanningScope scanningScope)
{
Settings newSettings = m_settings;
newSettings.scanningScope = scanningScope;
settingsChanged(newSettings);
}
-void TodoPlugin::todoItemClicked(const TodoItem &item)
+void TodoPluginPrivate::todoItemClicked(const TodoItem &item)
{
if (item.file.exists())
Core::EditorManager::openEditorAt(item.file.toString(), item.line);
}
-void TodoPlugin::createItemsProvider()
+void TodoPluginPrivate::createItemsProvider()
{
m_todoItemsProvider = new TodoItemsProvider(m_settings, this);
}
-void TodoPlugin::createTodoOutputPane()
+void TodoPluginPrivate::createTodoOutputPane()
{
m_todoOutputPane = new TodoOutputPane(m_todoItemsProvider->todoItemsModel(), &m_settings, this);
m_todoOutputPane->setScanningScope(m_settings.scanningScope);
connect(m_todoOutputPane, &TodoOutputPane::scanningScopeChanged,
- this, &TodoPlugin::scanningScopeChanged);
+ this, &TodoPluginPrivate::scanningScopeChanged);
connect(m_todoOutputPane, &TodoOutputPane::todoItemClicked,
- this, &TodoPlugin::todoItemClicked);
+ this, &TodoPluginPrivate::todoItemClicked);
}
-void TodoPlugin::createOptionsPage()
+TodoPlugin::TodoPlugin()
{
- m_optionsPage = new OptionsPage(m_settings, this);
- connect(m_optionsPage, &OptionsPage::settingsChanged,
- this, &TodoPlugin::settingsChanged);
+ qRegisterMetaType<TodoItem>("TodoItem");
+}
+
+TodoPlugin::~TodoPlugin()
+{
+ delete d;
+}
+
+bool TodoPlugin::initialize(const QStringList& args, QString *errMsg)
+{
+ Q_UNUSED(args)
+ Q_UNUSED(errMsg)
+
+ d = new TodoPluginPrivate;
+
+ return true;
}
} // namespace Internal
diff --git a/src/plugins/todo/todoplugin.h b/src/plugins/todo/todoplugin.h
index d3e3b1e91e8..124d29387c7 100644
--- a/src/plugins/todo/todoplugin.h
+++ b/src/plugins/todo/todoplugin.h
@@ -26,41 +26,24 @@
#pragma once
-#include "settings.h"
-
#include <extensionsystem/iplugin.h>
namespace Todo {
namespace Internal {
-class TodoOutputPane;
-class OptionsPage;
-class TodoItemsProvider;
-class TodoItem;
-
-class TodoPlugin : public ExtensionSystem::IPlugin
+class TodoPlugin final : public ExtensionSystem::IPlugin
{
Q_OBJECT
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QtCreatorPlugin" FILE "Todo.json")
public:
TodoPlugin();
- ~TodoPlugin() override;
+ ~TodoPlugin() final;
- bool initialize(const QStringList &arguments, QString *errorString) override;
+ bool initialize(const QStringList &arguments, QString *errorString) final;
private:
- void settingsChanged(const Settings &settings);
- void scanningScopeChanged(ScanningScope scanningScope);
- void todoItemClicked(const TodoItem &item);
- void createItemsProvider();
- void createTodoOutputPane();
- void createOptionsPage();
-
- Settings m_settings;
- TodoOutputPane *m_todoOutputPane = nullptr;
- OptionsPage *m_optionsPage = nullptr;
- TodoItemsProvider *m_todoItemsProvider = nullptr;
+ class TodoPluginPrivate *d = nullptr;
};
} // namespace Internal