Nim: Move code style related code to nimcodestylesettingspage.cpp

Not necessarily the final setup, but a step closer.

The selected style doesn't seem to stick anymore, but that's already
the case in 11.x.

Change-Id: I6c094c1222147c31456cf843397ffaaae9252a30
Reviewed-by: Christian Stenger <christian.stenger@qt.io>
This commit is contained in:
hjk
2023-07-17 13:04:50 +02:00
parent d127336753
commit bce9b9ffaa
4 changed files with 96 additions and 77 deletions

View File

@@ -3,14 +3,19 @@
#include "nimcodestylesettingspage.h" #include "nimcodestylesettingspage.h"
#include "nimcodestylepreferencesfactory.h"
#include "nimsettings.h"
#include "../nimconstants.h" #include "../nimconstants.h"
#include "../nimtr.h" #include "../nimtr.h"
#include "nimsettings.h"
#include <texteditor/simplecodestylepreferences.h> #include <coreplugin/icore.h>
#include <texteditor/codestyleeditor.h> #include <texteditor/codestyleeditor.h>
#include <texteditor/texteditorsettings.h> #include <texteditor/codestylepool.h>
#include <texteditor/icodestylepreferencesfactory.h>
#include <texteditor/simplecodestylepreferences.h>
#include <texteditor/tabsettings.h> #include <texteditor/tabsettings.h>
#include <texteditor/texteditorsettings.h>
#include <QVBoxLayout> #include <QVBoxLayout>
@@ -18,12 +23,78 @@ using namespace TextEditor;
namespace Nim { namespace Nim {
static SimpleCodeStylePreferences *m_globalCodeStyle = nullptr;
static CodeStylePool *pool = nullptr;
SimpleCodeStylePreferences *globalCodeStyle()
{
QTC_CHECK(m_globalCodeStyle);
return m_globalCodeStyle;
}
static void createGlobalCodeStyle()
{
auto factory = new NimCodeStylePreferencesFactory();
TextEditorSettings::registerCodeStyleFactory(factory);
// code style pool
pool = new CodeStylePool(factory);
TextEditorSettings::registerCodeStylePool(Nim::Constants::C_NIMLANGUAGE_ID, pool);
m_globalCodeStyle = new SimpleCodeStylePreferences();
m_globalCodeStyle->setDelegatingPool(pool);
m_globalCodeStyle->setDisplayName(Tr::tr("Global", "Settings"));
m_globalCodeStyle->setId(Nim::Constants::C_NIMGLOBALCODESTYLE_ID);
pool->addCodeStyle(m_globalCodeStyle);
TextEditorSettings::registerCodeStyle(Nim::Constants::C_NIMLANGUAGE_ID, m_globalCodeStyle);
auto nimCodeStyle = new SimpleCodeStylePreferences();
nimCodeStyle->setId("nim");
nimCodeStyle->setDisplayName(Tr::tr("Nim"));
nimCodeStyle->setReadOnly(true);
TabSettings nimTabSettings;
nimTabSettings.m_tabPolicy = TabSettings::SpacesOnlyTabPolicy;
nimTabSettings.m_tabSize = 2;
nimTabSettings.m_indentSize = 2;
nimTabSettings.m_continuationAlignBehavior = TabSettings::ContinuationAlignWithIndent;
nimCodeStyle->setTabSettings(nimTabSettings);
pool->addCodeStyle(nimCodeStyle);
m_globalCodeStyle->setCurrentDelegate(nimCodeStyle);
pool->loadCustomCodeStyles();
// load global settings (after built-in settings are added to the pool)
QSettings *s = Core::ICore::settings();
m_globalCodeStyle->fromSettings(QLatin1String(Nim::Constants::C_NIMLANGUAGE_ID), s);
TextEditorSettings::registerMimeTypeForLanguageId(Nim::Constants::C_NIM_MIMETYPE,
Nim::Constants::C_NIMLANGUAGE_ID);
TextEditorSettings::registerMimeTypeForLanguageId(Nim::Constants::C_NIM_SCRIPT_MIMETYPE,
Nim::Constants::C_NIMLANGUAGE_ID);
}
static void destroyGlobalCodeStyle()
{
TextEditorSettings::unregisterCodeStyle(Nim::Constants::C_NIMLANGUAGE_ID);
TextEditorSettings::unregisterCodeStylePool(Nim::Constants::C_NIMLANGUAGE_ID);
TextEditorSettings::unregisterCodeStyleFactory(Nim::Constants::C_NIMLANGUAGE_ID);
delete m_globalCodeStyle;
m_globalCodeStyle = nullptr;
delete pool;
pool = nullptr;
}
class NimCodeStyleSettingsWidget : public Core::IOptionsPageWidget class NimCodeStyleSettingsWidget : public Core::IOptionsPageWidget
{ {
public: public:
NimCodeStyleSettingsWidget() NimCodeStyleSettingsWidget()
{ {
auto originalTabPreferences = NimSettings::globalCodeStyle(); auto originalTabPreferences = globalCodeStyle();
m_nimCodeStylePreferences = new SimpleCodeStylePreferences(this); m_nimCodeStylePreferences = new SimpleCodeStylePreferences(this);
m_nimCodeStylePreferences->setDelegatingPool(originalTabPreferences->delegatingPool()); m_nimCodeStylePreferences->setDelegatingPool(originalTabPreferences->delegatingPool());
m_nimCodeStylePreferences->setTabSettings(originalTabPreferences->tabSettings()); m_nimCodeStylePreferences->setTabSettings(originalTabPreferences->tabSettings());
@@ -36,12 +107,25 @@ public:
auto layout = new QVBoxLayout(this); auto layout = new QVBoxLayout(this);
layout->addWidget(editor); layout->addWidget(editor);
QTC_ASSERT(m_globalCodeStyle, return);
QSettings *s = Core::ICore::settings();
m_globalCodeStyle->toSettings(QLatin1String(Nim::Constants::C_NIMLANGUAGE_ID), s);
}
void apply() final
{
QTC_ASSERT(m_globalCodeStyle, return);
QSettings *s = Core::ICore::settings();
m_globalCodeStyle->toSettings(QLatin1String(Nim::Constants::C_NIMLANGUAGE_ID), s);
} }
private: private:
TextEditor::SimpleCodeStylePreferences *m_nimCodeStylePreferences; TextEditor::SimpleCodeStylePreferences *m_nimCodeStylePreferences;
}; };
// NimCodeStyleSettingsPage
NimCodeStyleSettingsPage::NimCodeStyleSettingsPage() NimCodeStyleSettingsPage::NimCodeStyleSettingsPage()
{ {
setId(Nim::Constants::C_NIMCODESTYLESETTINGSPAGE_ID); setId(Nim::Constants::C_NIMCODESTYLESETTINGSPAGE_ID);
@@ -50,6 +134,13 @@ NimCodeStyleSettingsPage::NimCodeStyleSettingsPage()
setDisplayCategory(Tr::tr("Nim")); setDisplayCategory(Tr::tr("Nim"));
setCategoryIconPath(":/nim/images/settingscategory_nim.png"); setCategoryIconPath(":/nim/images/settingscategory_nim.png");
setWidgetCreator([] { return new NimCodeStyleSettingsWidget; }); setWidgetCreator([] { return new NimCodeStyleSettingsWidget; });
createGlobalCodeStyle();
}
NimCodeStyleSettingsPage::~NimCodeStyleSettingsPage()
{
destroyGlobalCodeStyle();
} }
} // Nim } // Nim

View File

@@ -11,6 +11,7 @@ class NimCodeStyleSettingsPage final : public Core::IOptionsPage
{ {
public: public:
NimCodeStyleSettingsPage(); NimCodeStyleSettingsPage();
~NimCodeStyleSettingsPage();
}; };
} // Nim } // Nim

View File

@@ -5,26 +5,16 @@
#include "../nimconstants.h" #include "../nimconstants.h"
#include "../nimtr.h" #include "../nimtr.h"
#include "nimcodestylepreferencesfactory.h"
#include <coreplugin/dialogs/ioptionspage.h> #include <coreplugin/dialogs/ioptionspage.h>
#include <coreplugin/icore.h> #include <coreplugin/icore.h>
#include <texteditor/codestylepool.h>
#include <texteditor/icodestylepreferencesfactory.h>
#include <texteditor/simplecodestylepreferences.h>
#include <texteditor/tabsettings.h>
#include <texteditor/texteditorsettings.h>
#include <utils/layoutbuilder.h> #include <utils/layoutbuilder.h>
using namespace TextEditor;
using namespace Utils; using namespace Utils;
namespace Nim { namespace Nim {
static SimpleCodeStylePreferences *m_globalCodeStyle = nullptr;
NimSettings &settings() NimSettings &settings()
{ {
static NimSettings theSettings; static NimSettings theSettings;
@@ -47,48 +37,6 @@ NimSettings::NimSettings()
}; };
}); });
// code style factory
auto factory = new NimCodeStylePreferencesFactory();
TextEditorSettings::registerCodeStyleFactory(factory);
// code style pool
auto pool = new CodeStylePool(factory, this);
TextEditorSettings::registerCodeStylePool(Nim::Constants::C_NIMLANGUAGE_ID, pool);
m_globalCodeStyle = new SimpleCodeStylePreferences();
m_globalCodeStyle->setDelegatingPool(pool);
m_globalCodeStyle->setDisplayName(Tr::tr("Global", "Settings"));
m_globalCodeStyle->setId(Nim::Constants::C_NIMGLOBALCODESTYLE_ID);
pool->addCodeStyle(m_globalCodeStyle);
TextEditorSettings::registerCodeStyle(Nim::Constants::C_NIMLANGUAGE_ID, m_globalCodeStyle);
auto nimCodeStyle = new SimpleCodeStylePreferences();
nimCodeStyle->setId("nim");
nimCodeStyle->setDisplayName(Tr::tr("Nim"));
nimCodeStyle->setReadOnly(true);
TabSettings nimTabSettings;
nimTabSettings.m_tabPolicy = TabSettings::SpacesOnlyTabPolicy;
nimTabSettings.m_tabSize = 2;
nimTabSettings.m_indentSize = 2;
nimTabSettings.m_continuationAlignBehavior = TabSettings::ContinuationAlignWithIndent;
nimCodeStyle->setTabSettings(nimTabSettings);
pool->addCodeStyle(nimCodeStyle);
m_globalCodeStyle->setCurrentDelegate(nimCodeStyle);
pool->loadCustomCodeStyles();
// load global settings (after built-in settings are added to the pool)
QSettings *s = Core::ICore::settings();
m_globalCodeStyle->fromSettings(QLatin1String(Nim::Constants::C_NIMLANGUAGE_ID), s);
TextEditorSettings::registerMimeTypeForLanguageId(Nim::Constants::C_NIM_MIMETYPE,
Nim::Constants::C_NIMLANGUAGE_ID);
TextEditorSettings::registerMimeTypeForLanguageId(Nim::Constants::C_NIM_SCRIPT_MIMETYPE,
Nim::Constants::C_NIMLANGUAGE_ID);
nimSuggestPath.setSettingsKey("Command"); nimSuggestPath.setSettingsKey("Command");
nimSuggestPath.setExpectedKind(PathChooser::ExistingCommand); nimSuggestPath.setExpectedKind(PathChooser::ExistingCommand);
nimSuggestPath.setLabelText(Tr::tr("Path:")); nimSuggestPath.setLabelText(Tr::tr("Path:"));
@@ -96,22 +44,6 @@ NimSettings::NimSettings()
readSettings(); readSettings();
} }
NimSettings::~NimSettings()
{
TextEditorSettings::unregisterCodeStyle(Nim::Constants::C_NIMLANGUAGE_ID);
TextEditorSettings::unregisterCodeStylePool(Nim::Constants::C_NIMLANGUAGE_ID);
TextEditorSettings::unregisterCodeStyleFactory(Nim::Constants::C_NIMLANGUAGE_ID);
delete m_globalCodeStyle;
m_globalCodeStyle = nullptr;
}
SimpleCodeStylePreferences *NimSettings::globalCodeStyle()
{
QTC_ASSERT(m_globalCodeStyle, settings()); // Ensure creation
return m_globalCodeStyle;
}
// NimSettingsPage // NimSettingsPage
class NimSettingsPage final : public Core::IOptionsPage class NimSettingsPage final : public Core::IOptionsPage

View File

@@ -5,19 +5,14 @@
#include <utils/aspects.h> #include <utils/aspects.h>
namespace TextEditor { class SimpleCodeStylePreferences; }
namespace Nim { namespace Nim {
class NimSettings final : public Utils::AspectContainer class NimSettings final : public Utils::AspectContainer
{ {
public: public:
NimSettings(); NimSettings();
~NimSettings();
Utils::FilePathAspect nimSuggestPath{this}; Utils::FilePathAspect nimSuggestPath{this};
static TextEditor::SimpleCodeStylePreferences *globalCodeStyle();
}; };
NimSettings &settings(); NimSettings &settings();