HostInterface: Make SetUserDirectory() overridable by frontends
This commit is contained in:
@ -7,18 +7,18 @@ static QString GetFullKey(const char* section, const char* key)
|
||||
return QStringLiteral("%1/%2").arg(section, key);
|
||||
}
|
||||
|
||||
QtSettingsInterface::QtSettingsInterface(QSettings& settings) : m_settings(settings) {}
|
||||
QtSettingsInterface::QtSettingsInterface(QSettings* settings) : m_settings(settings) {}
|
||||
|
||||
QtSettingsInterface::~QtSettingsInterface() = default;
|
||||
|
||||
void QtSettingsInterface::Clear()
|
||||
{
|
||||
m_settings.clear();
|
||||
m_settings->clear();
|
||||
}
|
||||
|
||||
int QtSettingsInterface::GetIntValue(const char* section, const char* key, int default_value /*= 0*/)
|
||||
{
|
||||
QVariant value = m_settings.value(GetFullKey(section, key));
|
||||
QVariant value = m_settings->value(GetFullKey(section, key));
|
||||
if (!value.isValid())
|
||||
return default_value;
|
||||
|
||||
@ -32,7 +32,7 @@ int QtSettingsInterface::GetIntValue(const char* section, const char* key, int d
|
||||
|
||||
float QtSettingsInterface::GetFloatValue(const char* section, const char* key, float default_value /*= 0.0f*/)
|
||||
{
|
||||
QVariant value = m_settings.value(GetFullKey(section, key));
|
||||
QVariant value = m_settings->value(GetFullKey(section, key));
|
||||
if (!value.isValid())
|
||||
return default_value;
|
||||
|
||||
@ -46,40 +46,40 @@ float QtSettingsInterface::GetFloatValue(const char* section, const char* key, f
|
||||
|
||||
bool QtSettingsInterface::GetBoolValue(const char* section, const char* key, bool default_value /*= false*/)
|
||||
{
|
||||
QVariant value = m_settings.value(GetFullKey(section, key));
|
||||
QVariant value = m_settings->value(GetFullKey(section, key));
|
||||
return value.isValid() ? value.toBool() : default_value;
|
||||
}
|
||||
|
||||
std::string QtSettingsInterface::GetStringValue(const char* section, const char* key,
|
||||
const char* default_value /*= ""*/)
|
||||
{
|
||||
QVariant value = m_settings.value(GetFullKey(section, key));
|
||||
QVariant value = m_settings->value(GetFullKey(section, key));
|
||||
return value.isValid() ? value.toString().toStdString() : std::string(default_value);
|
||||
}
|
||||
|
||||
void QtSettingsInterface::SetIntValue(const char* section, const char* key, int value)
|
||||
{
|
||||
m_settings.setValue(GetFullKey(section, key), QVariant(value));
|
||||
m_settings->setValue(GetFullKey(section, key), QVariant(value));
|
||||
}
|
||||
|
||||
void QtSettingsInterface::SetFloatValue(const char* section, const char* key, float value)
|
||||
{
|
||||
m_settings.setValue(GetFullKey(section, key), QString::number(value));
|
||||
m_settings->setValue(GetFullKey(section, key), QString::number(value));
|
||||
}
|
||||
|
||||
void QtSettingsInterface::SetBoolValue(const char* section, const char* key, bool value)
|
||||
{
|
||||
m_settings.setValue(GetFullKey(section, key), QVariant(value));
|
||||
m_settings->setValue(GetFullKey(section, key), QVariant(value));
|
||||
}
|
||||
|
||||
void QtSettingsInterface::SetStringValue(const char* section, const char* key, const char* value)
|
||||
{
|
||||
m_settings.setValue(GetFullKey(section, key), QVariant(value));
|
||||
m_settings->setValue(GetFullKey(section, key), QVariant(value));
|
||||
}
|
||||
|
||||
std::vector<std::string> QtSettingsInterface::GetStringList(const char* section, const char* key)
|
||||
{
|
||||
QVariant value = m_settings.value(GetFullKey(section, key));
|
||||
QVariant value = m_settings->value(GetFullKey(section, key));
|
||||
if (value.type() == QVariant::String)
|
||||
return {value.toString().toStdString()};
|
||||
else if (value.type() != QVariant::StringList)
|
||||
@ -99,7 +99,7 @@ void QtSettingsInterface::SetStringList(const char* section, const char* key,
|
||||
QString full_key = GetFullKey(section, key);
|
||||
if (items.empty())
|
||||
{
|
||||
m_settings.remove(full_key);
|
||||
m_settings->remove(full_key);
|
||||
return;
|
||||
}
|
||||
|
||||
@ -108,28 +108,28 @@ void QtSettingsInterface::SetStringList(const char* section, const char* key,
|
||||
std::transform(items.begin(), items.end(), std::back_inserter(sl), [](const std::string_view& sv) {
|
||||
return QString::fromLocal8Bit(sv.data(), static_cast<int>(sv.size()));
|
||||
});
|
||||
m_settings.setValue(full_key, sl);
|
||||
m_settings->setValue(full_key, sl);
|
||||
}
|
||||
|
||||
bool QtSettingsInterface::RemoveFromStringList(const char* section, const char* key, const char* item)
|
||||
{
|
||||
QString full_key = GetFullKey(section, key);
|
||||
QVariant var = m_settings.value(full_key);
|
||||
QVariant var = m_settings->value(full_key);
|
||||
QStringList sl = var.toStringList();
|
||||
if (sl.removeAll(item) == 0)
|
||||
return false;
|
||||
|
||||
if (sl.isEmpty())
|
||||
m_settings.remove(full_key);
|
||||
m_settings->remove(full_key);
|
||||
else
|
||||
m_settings.setValue(full_key, sl);
|
||||
m_settings->setValue(full_key, sl);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool QtSettingsInterface::AddToStringList(const char* section, const char* key, const char* item)
|
||||
{
|
||||
QString full_key = GetFullKey(section, key);
|
||||
QVariant var = m_settings.value(full_key);
|
||||
QVariant var = m_settings->value(full_key);
|
||||
|
||||
QStringList sl = (var.type() == QVariant::StringList) ? var.toStringList() : QStringList();
|
||||
QString qitem(item);
|
||||
@ -137,11 +137,11 @@ bool QtSettingsInterface::AddToStringList(const char* section, const char* key,
|
||||
return false;
|
||||
|
||||
sl.push_back(qitem);
|
||||
m_settings.setValue(full_key, sl);
|
||||
m_settings->setValue(full_key, sl);
|
||||
return true;
|
||||
}
|
||||
|
||||
void QtSettingsInterface::DeleteValue(const char* section, const char* key)
|
||||
{
|
||||
m_settings.remove(GetFullKey(section, key));
|
||||
m_settings->remove(GetFullKey(section, key));
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user