forked from qt-creator/qt-creator
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:
@@ -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
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ class NimCodeStyleSettingsPage final : public Core::IOptionsPage
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
NimCodeStyleSettingsPage();
|
NimCodeStyleSettingsPage();
|
||||||
|
~NimCodeStyleSettingsPage();
|
||||||
};
|
};
|
||||||
|
|
||||||
} // Nim
|
} // Nim
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
Reference in New Issue
Block a user