mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 19:50:05 +00:00
Refactor settings to be managed by singletons
This commit is contained in:
parent
acc782b2bc
commit
b66ca2cb09
21 changed files with 138 additions and 133 deletions
|
|
@ -16,10 +16,10 @@ namespace settings
|
|||
|
||||
static const std::string logPrefix_ = "scwx::qt::settings::general_settings";
|
||||
|
||||
class GeneralSettingsImpl
|
||||
class GeneralSettings::Impl
|
||||
{
|
||||
public:
|
||||
explicit GeneralSettingsImpl()
|
||||
explicit Impl()
|
||||
{
|
||||
std::string defaultDefaultAlertActionValue =
|
||||
types::GetAlertActionName(types::AlertAction::Go);
|
||||
|
|
@ -102,7 +102,7 @@ public:
|
|||
{ return !value.empty(); });
|
||||
}
|
||||
|
||||
~GeneralSettingsImpl() {}
|
||||
~Impl() {}
|
||||
|
||||
SettingsVariable<bool> debugEnabled_ {"debug_enabled"};
|
||||
SettingsVariable<std::string> defaultAlertAction_ {"default_alert_action"};
|
||||
|
|
@ -120,7 +120,7 @@ public:
|
|||
};
|
||||
|
||||
GeneralSettings::GeneralSettings() :
|
||||
SettingsCategory("general"), p(std::make_unique<GeneralSettingsImpl>())
|
||||
SettingsCategory("general"), p(std::make_unique<Impl>())
|
||||
{
|
||||
RegisterVariables({&p->debugEnabled_,
|
||||
&p->defaultAlertAction_,
|
||||
|
|
@ -221,6 +221,12 @@ bool GeneralSettings::Shutdown()
|
|||
return dataChanged;
|
||||
}
|
||||
|
||||
GeneralSettings& GeneralSettings::Instance()
|
||||
{
|
||||
static GeneralSettings generalSettings_;
|
||||
return generalSettings_;
|
||||
}
|
||||
|
||||
bool operator==(const GeneralSettings& lhs, const GeneralSettings& rhs)
|
||||
{
|
||||
return (lhs.p->debugEnabled_ == rhs.p->debugEnabled_ &&
|
||||
|
|
|
|||
|
|
@ -13,8 +13,6 @@ namespace qt
|
|||
namespace settings
|
||||
{
|
||||
|
||||
class GeneralSettingsImpl;
|
||||
|
||||
class GeneralSettings : public SettingsCategory
|
||||
{
|
||||
public:
|
||||
|
|
@ -41,13 +39,16 @@ public:
|
|||
SettingsVariable<std::string>& maptiler_api_key() const;
|
||||
SettingsVariable<bool>& update_notifications_enabled() const;
|
||||
|
||||
static GeneralSettings& Instance();
|
||||
|
||||
friend bool operator==(const GeneralSettings& lhs,
|
||||
const GeneralSettings& rhs);
|
||||
|
||||
bool Shutdown();
|
||||
|
||||
private:
|
||||
std::unique_ptr<GeneralSettingsImpl> p;
|
||||
class Impl;
|
||||
std::unique_ptr<Impl> p;
|
||||
};
|
||||
|
||||
} // namespace settings
|
||||
|
|
|
|||
|
|
@ -35,7 +35,7 @@ static const std::string kDefaultRadarProductGroupString_ = "L3";
|
|||
static const std::array<std::string, kCount_> kDefaultRadarProduct_ {
|
||||
"N0B", "N0G", "N0C", "N0X"};
|
||||
|
||||
class MapSettingsImpl
|
||||
class MapSettings::Impl
|
||||
{
|
||||
public:
|
||||
struct MapData
|
||||
|
|
@ -47,7 +47,7 @@ public:
|
|||
SettingsVariable<std::string> radarProduct_ {kRadarProductName_};
|
||||
};
|
||||
|
||||
explicit MapSettingsImpl()
|
||||
explicit Impl()
|
||||
{
|
||||
for (std::size_t i = 0; i < kCount_; i++)
|
||||
{
|
||||
|
|
@ -101,7 +101,7 @@ public:
|
|||
}
|
||||
}
|
||||
|
||||
~MapSettingsImpl() {}
|
||||
~Impl() {}
|
||||
|
||||
void SetDefaults(std::size_t i)
|
||||
{
|
||||
|
|
@ -111,12 +111,30 @@ public:
|
|||
map_[i].radarProduct_.SetValueToDefault();
|
||||
}
|
||||
|
||||
friend void tag_invoke(boost::json::value_from_tag,
|
||||
boost::json::value& jv,
|
||||
const MapData& data)
|
||||
{
|
||||
jv = {{kMapStyleName_, data.mapStyle_.GetValue()},
|
||||
{kRadarSiteName_, data.radarSite_.GetValue()},
|
||||
{kRadarProductGroupName_, data.radarProductGroup_.GetValue()},
|
||||
{kRadarProductName_, data.radarProduct_.GetValue()}};
|
||||
}
|
||||
|
||||
friend bool operator==(const MapData& lhs, const MapData& rhs)
|
||||
{
|
||||
return (lhs.mapStyle_ == rhs.mapStyle_ && //
|
||||
lhs.radarSite_ == rhs.radarSite_ &&
|
||||
lhs.radarProductGroup_ == rhs.radarProductGroup_ &&
|
||||
lhs.radarProduct_ == rhs.radarProduct_);
|
||||
}
|
||||
|
||||
std::array<MapData, kCount_> map_ {};
|
||||
std::vector<SettingsVariableBase*> variables_ {};
|
||||
};
|
||||
|
||||
MapSettings::MapSettings() :
|
||||
SettingsCategory("maps"), p(std::make_unique<MapSettingsImpl>())
|
||||
SettingsCategory("maps"), p(std::make_unique<Impl>())
|
||||
{
|
||||
RegisterVariables(p->variables_);
|
||||
SetDefaults();
|
||||
|
|
@ -161,7 +179,7 @@ bool MapSettings::Shutdown()
|
|||
// Commit settings that are managed separate from the settings dialog
|
||||
for (std::size_t i = 0; i < kCount_; ++i)
|
||||
{
|
||||
MapSettingsImpl::MapData& mapRecordSettings = p->map_[i];
|
||||
Impl::MapData& mapRecordSettings = p->map_[i];
|
||||
|
||||
dataChanged |= mapRecordSettings.mapStyle_.Commit();
|
||||
}
|
||||
|
|
@ -184,7 +202,7 @@ bool MapSettings::ReadJson(const boost::json::object& json)
|
|||
if (i < mapArray.size() && mapArray.at(i).is_object())
|
||||
{
|
||||
const boost::json::object& mapRecord = mapArray.at(i).as_object();
|
||||
MapSettingsImpl::MapData& mapRecordSettings = p->map_[i];
|
||||
Impl::MapData& mapRecordSettings = p->map_[i];
|
||||
|
||||
// Load JSON Elements
|
||||
validated &= mapRecordSettings.mapStyle_.ReadValue(mapRecord);
|
||||
|
|
@ -234,14 +252,10 @@ void MapSettings::WriteJson(boost::json::object& json) const
|
|||
json.insert_or_assign(name(), object);
|
||||
}
|
||||
|
||||
void tag_invoke(boost::json::value_from_tag,
|
||||
boost::json::value& jv,
|
||||
const MapSettingsImpl::MapData& data)
|
||||
MapSettings& MapSettings::Instance()
|
||||
{
|
||||
jv = {{kMapStyleName_, data.mapStyle_.GetValue()},
|
||||
{kRadarSiteName_, data.radarSite_.GetValue()},
|
||||
{kRadarProductGroupName_, data.radarProductGroup_.GetValue()},
|
||||
{kRadarProductName_, data.radarProduct_.GetValue()}};
|
||||
static MapSettings mapSettings_;
|
||||
return mapSettings_;
|
||||
}
|
||||
|
||||
bool operator==(const MapSettings& lhs, const MapSettings& rhs)
|
||||
|
|
@ -249,15 +263,6 @@ bool operator==(const MapSettings& lhs, const MapSettings& rhs)
|
|||
return (lhs.p->map_ == rhs.p->map_);
|
||||
}
|
||||
|
||||
bool operator==(const MapSettingsImpl::MapData& lhs,
|
||||
const MapSettingsImpl::MapData& rhs)
|
||||
{
|
||||
return (lhs.mapStyle_ == rhs.mapStyle_ && //
|
||||
lhs.radarSite_ == rhs.radarSite_ &&
|
||||
lhs.radarProductGroup_ == rhs.radarProductGroup_ &&
|
||||
lhs.radarProduct_ == rhs.radarProduct_);
|
||||
}
|
||||
|
||||
} // namespace settings
|
||||
} // namespace qt
|
||||
} // namespace scwx
|
||||
|
|
|
|||
|
|
@ -13,8 +13,6 @@ namespace qt
|
|||
namespace settings
|
||||
{
|
||||
|
||||
class MapSettingsImpl;
|
||||
|
||||
class MapSettings : public SettingsCategory
|
||||
{
|
||||
public:
|
||||
|
|
@ -52,10 +50,13 @@ public:
|
|||
*/
|
||||
void WriteJson(boost::json::object& json) const override;
|
||||
|
||||
static MapSettings& Instance();
|
||||
|
||||
friend bool operator==(const MapSettings& lhs, const MapSettings& rhs);
|
||||
|
||||
private:
|
||||
std::unique_ptr<MapSettingsImpl> p;
|
||||
class Impl;
|
||||
std::unique_ptr<Impl> p;
|
||||
};
|
||||
|
||||
} // namespace settings
|
||||
|
|
|
|||
|
|
@ -72,10 +72,10 @@ static const std::map<
|
|||
static const std::string kDefaultKey_ {"???"};
|
||||
static const awips::Phenomenon kDefaultPhenomenon_ {awips::Phenomenon::Marine};
|
||||
|
||||
class PaletteSettingsImpl
|
||||
class PaletteSettings::Impl
|
||||
{
|
||||
public:
|
||||
explicit PaletteSettingsImpl()
|
||||
explicit Impl()
|
||||
{
|
||||
for (const auto& name : kPaletteKeys_)
|
||||
{
|
||||
|
|
@ -120,7 +120,7 @@ public:
|
|||
}
|
||||
}
|
||||
|
||||
~PaletteSettingsImpl() {}
|
||||
~Impl() {}
|
||||
|
||||
static bool ValidateColor(const std::string& value);
|
||||
|
||||
|
|
@ -132,14 +132,14 @@ public:
|
|||
std::vector<SettingsVariableBase*> variables_ {};
|
||||
};
|
||||
|
||||
bool PaletteSettingsImpl::ValidateColor(const std::string& value)
|
||||
bool PaletteSettings::Impl::ValidateColor(const std::string& value)
|
||||
{
|
||||
static const std::regex re {"#[0-9A-Za-z]{8}"};
|
||||
return std::regex_match(value, re);
|
||||
}
|
||||
|
||||
PaletteSettings::PaletteSettings() :
|
||||
SettingsCategory("palette"), p(std::make_unique<PaletteSettingsImpl>())
|
||||
SettingsCategory("palette"), p(std::make_unique<Impl>())
|
||||
{
|
||||
RegisterVariables(p->variables_);
|
||||
SetDefaults();
|
||||
|
|
@ -200,6 +200,12 @@ const std::vector<awips::Phenomenon>& PaletteSettings::alert_phenomena()
|
|||
return kAlertPhenomena_;
|
||||
}
|
||||
|
||||
PaletteSettings& PaletteSettings::Instance()
|
||||
{
|
||||
static PaletteSettings paletteSettings_;
|
||||
return paletteSettings_;
|
||||
}
|
||||
|
||||
bool operator==(const PaletteSettings& lhs, const PaletteSettings& rhs)
|
||||
{
|
||||
return lhs.p->palette_ == rhs.p->palette_;
|
||||
|
|
|
|||
|
|
@ -14,8 +14,6 @@ namespace qt
|
|||
namespace settings
|
||||
{
|
||||
|
||||
class PaletteSettingsImpl;
|
||||
|
||||
class PaletteSettings : public SettingsCategory
|
||||
{
|
||||
public:
|
||||
|
|
@ -34,11 +32,14 @@ public:
|
|||
|
||||
static const std::vector<awips::Phenomenon>& alert_phenomena();
|
||||
|
||||
static PaletteSettings& Instance();
|
||||
|
||||
friend bool operator==(const PaletteSettings& lhs,
|
||||
const PaletteSettings& rhs);
|
||||
|
||||
private:
|
||||
std::unique_ptr<PaletteSettingsImpl> p;
|
||||
class Impl;
|
||||
std::unique_ptr<Impl> p;
|
||||
};
|
||||
|
||||
} // namespace settings
|
||||
|
|
|
|||
|
|
@ -169,8 +169,8 @@ SettingsVariable<std::string>& TextSettings::tooltip_method() const
|
|||
|
||||
TextSettings& TextSettings::Instance()
|
||||
{
|
||||
static TextSettings TextSettings_;
|
||||
return TextSettings_;
|
||||
static TextSettings textSettings_;
|
||||
return textSettings_;
|
||||
}
|
||||
|
||||
bool operator==(const TextSettings& lhs, const TextSettings& rhs)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue