# HG changeset patch # User Teemu Piippo # Date 1655235099 -10800 # Node ID e28f89b8ccdf4b6fa0f91bf82ca4980639fac5bc # Parent a6d937f8c0acd2e85bfd09b9c3106d51d7792a8c simplify settings further diff -r a6d937f8c0ac -r e28f89b8ccdf CMakeLists.txt --- a/CMakeLists.txt Tue Jun 14 20:44:07 2022 +0300 +++ b/CMakeLists.txt Tue Jun 14 22:31:39 2022 +0300 @@ -71,7 +71,6 @@ src/polygoncache.h src/ring.h src/settings.h - src/settingdefs.h src/typeconversions.h src/uiutilities.h src/version.h diff -r a6d937f8c0ac -r e28f89b8ccdf src/main.cpp --- a/src/main.cpp Tue Jun 14 20:44:07 2022 +0300 +++ b/src/main.cpp Tue Jun 14 22:31:39 2022 +0300 @@ -342,7 +342,6 @@ setSetting(recentlyOpenedFiles); setSetting(renderPreferences.style); setSetting(renderPreferences.drawAxes); - setSetting("hello world"); libraries.storeToSettings(); }; const auto updateRecentlyOpenedDocumentsMenu = [&]{ diff -r a6d937f8c0ac -r e28f89b8ccdf src/settingdefs.h --- a/src/settingdefs.h Tue Jun 14 20:44:07 2022 +0300 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,33 +0,0 @@ -#include -#include "libraries.h" -#include "gl/common.h" - -#ifndef SETTING -enum class Setting { -# define SETTING(NAME, DEFVALUE) NAME, -# define AUTOMATIC_SETTINGS_DEF -#endif - -// Rendering options -SETTING(Locale, QString{"system"}) -SETTING(BackgroundColor, (QColor{48, 48, 48})) -SETTING(MainColor, (QColor{255, 255, 64})) -SETTING(SelectedColor, (QColor{32, 32, 224})) -SETTING(LineThickness, 2.0f) -SETTING(LineAntiAliasing, true) -SETTING(RenderStyle, gl::RenderStyle::Normal) -SETTING(DrawWireframe, false) -SETTING(DrawAxes, true) -SETTING(MainWindowGeometry, QByteArray{}) -SETTING(MainSplitterState, QByteArray{}) -SETTING(RecentFiles, QStringList{}) -SETTING(ViewMode, QMdiArea::TabbedView) - -// File management options -SETTING(Libraries, QVector{}) - -#ifdef AUTOMATIC_SETTINGS_DEF -}; -# undef SETTING -# undef AUTOMATIC_SETTINGS_DEF -#endif diff -r a6d937f8c0ac -r e28f89b8ccdf src/settings.h --- a/src/settings.h Tue Jun 14 20:44:07 2022 +0300 +++ b/src/settings.h Tue Jun 14 22:31:39 2022 +0300 @@ -1,13 +1,20 @@ #ifndef SETTINGS_H #define SETTINGS_H #include -#include "settingdefs.h" +#include +#include "libraries.h" +#include "gl/common.h" // SettingType - get type of setting by enumerator -template +template +struct SettingId{}; + +template struct SettingInfo{}; #define SETTING(NAME, DEFVALUE) \ + namespace SettingIdTypes { class NAME; } \ + namespace Setting { constexpr SettingId NAME; } \ template<> \ struct SettingInfo \ { \ @@ -18,24 +25,47 @@ return value; \ }; \ }; -#include "settingdefs.h" + +// ----------------------------------------------------------------------------- +// Setting definitions + +// Rendering options +SETTING(Locale, QStringLiteral("system")) +SETTING(BackgroundColor, (QColor{48, 48, 48})) +SETTING(MainColor, (QColor{255, 255, 64})) +SETTING(SelectedColor, (QColor{32, 32, 224})) +SETTING(LineThickness, 2.0f) +SETTING(LineAntiAliasing, true) +SETTING(RenderStyle, gl::RenderStyle::Normal) +SETTING(DrawWireframe, false) +SETTING(DrawAxes, true) +SETTING(MainWindowGeometry, QByteArray{}) +SETTING(MainSplitterState, QByteArray{}) +SETTING(RecentFiles, QStringList{}) +SETTING(ViewMode, QMdiArea::TabbedView) + +// File management options +SETTING(Libraries, QVector{}) + +// End of setting definitions +// ----------------------------------------------------------------------------- #undef SETTING -template +template using SettingType_t = typename SettingInfo::type; static_assert(std::is_same_v, bool>); -template +template const char* settingName = SettingInfo::name; -template +template inline auto settingDefaultValue() { return SettingInfo::defaultValue(); } // get() - get setting by enumerator -template +template inline SettingType_t setting() { static const QVariant defvariant = QVariant::fromValue(settingDefaultValue()); @@ -44,7 +74,7 @@ } // setSetting() - set value of setting -template +template inline void setSetting(const SettingType_t& value) { if (value == settingDefaultValue()) {