forked from qt-creator/qt-creator
CppEditor: Move CppFileSettingsForProjectWidget to .cpp
... and de-pimpl/re-order there. Change-Id: I01b8e3d56ae28b0206dcd56a6cc04acf8c7b1942 Reviewed-by: Christian Kandeler <christian.kandeler@qt.io> Reviewed-by: <github-actions-qt-creator@cristianadam.eu>
This commit is contained in:
@@ -537,55 +537,57 @@ void CppFileSettingsForProject::saveSettings()
|
||||
m_project->setNamedSettings(projectSettingsKeyC, data);
|
||||
}
|
||||
|
||||
class CppFileSettingsForProjectWidget::Private
|
||||
class CppFileSettingsForProjectWidget : public ProjectExplorer::ProjectSettingsWidget
|
||||
{
|
||||
public:
|
||||
Private(const CppFileSettingsForProject &s) : settings(s) {}
|
||||
|
||||
void maybeClearHeaderSourceCache();
|
||||
void updateSubWidgetState() { widget.setEnabled(!settings.useGlobalSettings()); }
|
||||
|
||||
CppFileSettingsForProject settings;
|
||||
CppFileSettings initialSettings = settings.settings();
|
||||
CppFileSettingsWidget widget{&initialSettings};
|
||||
QCheckBox useGlobalSettingsCheckBox;
|
||||
const bool wasGlobal = settings.useGlobalSettings();
|
||||
};
|
||||
|
||||
CppFileSettingsForProjectWidget::CppFileSettingsForProjectWidget(
|
||||
const CppFileSettingsForProject &settings) : d(new Private(settings))
|
||||
{
|
||||
CppFileSettingsForProjectWidget(const CppFileSettingsForProject &settings)
|
||||
: m_settings(settings),
|
||||
m_initialSettings(settings.settings()),
|
||||
m_widget(&m_initialSettings),
|
||||
m_wasGlobal(settings.useGlobalSettings())
|
||||
{
|
||||
setGlobalSettingsId(Constants::CPP_FILE_SETTINGS_ID);
|
||||
const auto layout = new QVBoxLayout(this);
|
||||
layout->setContentsMargins(0, 0, 0, 0);
|
||||
layout->addWidget(&d->widget);
|
||||
layout->addWidget(&m_widget);
|
||||
|
||||
connect(this, &ProjectSettingsWidget::useGlobalSettingsChanged, this,
|
||||
[this](bool checked) {
|
||||
d->settings.setUseGlobalSettings(checked);
|
||||
connect(this, &ProjectSettingsWidget::useGlobalSettingsChanged, this, [this](bool checked) {
|
||||
m_settings.setUseGlobalSettings(checked);
|
||||
if (!checked)
|
||||
d->settings.setSettings(d->widget.currentSettings());
|
||||
d->maybeClearHeaderSourceCache();
|
||||
d->updateSubWidgetState();
|
||||
m_settings.setSettings(m_widget.currentSettings());
|
||||
maybeClearHeaderSourceCache();
|
||||
updateSubWidgetState();
|
||||
});
|
||||
connect(&d->widget, &CppFileSettingsWidget::userChange, this, [this] {
|
||||
d->settings.setSettings(d->widget.currentSettings());
|
||||
d->maybeClearHeaderSourceCache();
|
||||
|
||||
connect(&m_widget, &CppFileSettingsWidget::userChange, this, [this] {
|
||||
m_settings.setSettings(m_widget.currentSettings());
|
||||
maybeClearHeaderSourceCache();
|
||||
});
|
||||
d->updateSubWidgetState();
|
||||
}
|
||||
|
||||
CppFileSettingsForProjectWidget::~CppFileSettingsForProjectWidget() { delete d; }
|
||||
updateSubWidgetState();
|
||||
}
|
||||
|
||||
void CppFileSettingsForProjectWidget::Private::maybeClearHeaderSourceCache()
|
||||
{
|
||||
const CppFileSettings &s = settings.settings();
|
||||
if (settings.useGlobalSettings() != wasGlobal
|
||||
|| s.headerSearchPaths != initialSettings.headerSearchPaths
|
||||
|| s.sourceSearchPaths != initialSettings.sourceSearchPaths) {
|
||||
void maybeClearHeaderSourceCache()
|
||||
{
|
||||
const CppFileSettings &s = m_settings.settings();
|
||||
if (m_settings.useGlobalSettings() != m_wasGlobal
|
||||
|| s.headerSearchPaths != m_initialSettings.headerSearchPaths
|
||||
|| s.sourceSearchPaths != m_initialSettings.sourceSearchPaths) {
|
||||
CppEditorPlugin::clearHeaderSourceCache();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void updateSubWidgetState()
|
||||
{
|
||||
m_widget.setEnabled(!m_settings.useGlobalSettings());
|
||||
}
|
||||
|
||||
CppFileSettingsForProject m_settings;
|
||||
CppFileSettings m_initialSettings;
|
||||
CppFileSettingsWidget m_widget;
|
||||
QCheckBox m_useGlobalSettingsCheckBox;
|
||||
const bool m_wasGlobal;
|
||||
};
|
||||
|
||||
class CppFileSettingsProjectPanelFactory final : public ProjectPanelFactory
|
||||
{
|
||||
|
@@ -6,7 +6,6 @@
|
||||
#include "cppeditorconstants.h"
|
||||
|
||||
#include <coreplugin/dialogs/ioptionspage.h>
|
||||
#include <projectexplorer/projectsettingswidget.h>
|
||||
|
||||
#include <QDir>
|
||||
|
||||
@@ -74,17 +73,6 @@ public:
|
||||
CppFileSettingsPage();
|
||||
};
|
||||
|
||||
class CppFileSettingsForProjectWidget : public ProjectExplorer::ProjectSettingsWidget
|
||||
{
|
||||
public:
|
||||
CppFileSettingsForProjectWidget(const CppFileSettingsForProject &settings);
|
||||
~CppFileSettingsForProjectWidget();
|
||||
|
||||
private:
|
||||
class Private;
|
||||
Private * const d;
|
||||
};
|
||||
|
||||
CppFileSettings &globalCppFileSettings();
|
||||
|
||||
void setupCppFileSettings();
|
||||
|
Reference in New Issue
Block a user