Skip to content

Commit 2c50ed0

Browse files
committed
Migrate -lang setting from QSettings to settings.json
1 parent 1634dbf commit 2c50ed0

File tree

2 files changed

+8
-15
lines changed

2 files changed

+8
-15
lines changed

src/qt/forms/optionsdialog.ui

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -896,7 +896,7 @@
896896
<item>
897897
<widget class="QLabel" name="overriddenByCommandLineInfoLabel">
898898
<property name="text">
899-
<string>Options set in this dialog are overridden by the command line or in the configuration file:</string>
899+
<string>Options set in this dialog are overridden by the command line:</string>
900900
</property>
901901
<property name="textFormat">
902902
<enum>Qt::PlainText</enum>

src/qt/optionsmodel.cpp

Lines changed: 7 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -53,6 +53,7 @@ static const char* SettingName(OptionsModel::OptionID option)
5353
case OptionsModel::ProxyIPTor: return "onion";
5454
case OptionsModel::ProxyPortTor: return "onion";
5555
case OptionsModel::ProxyUseTor: return "onion";
56+
case OptionsModel::Language: return "lang";
5657
default: throw std::logic_error(strprintf("GUI option %i has no corresponding node setting.", option));
5758
}
5859
}
@@ -137,6 +138,7 @@ bool OptionsModel::Init(bilingual_str& error)
137138
ProxySetting onion = ParseProxyString(SettingToString(node().getPersistentSetting("onion"), GetDefaultProxyAddress().toStdString()));
138139
m_onion_ip = onion.ip;
139140
m_onion_port = onion.port;
141+
language = QString::fromStdString(SettingToString(node().getPersistentSetting("lang"), ""));
140142

141143
checkAndMigrate();
142144

@@ -190,7 +192,7 @@ bool OptionsModel::Init(bilingual_str& error)
190192
// These are shared with the core or have a command-line parameter
191193
// and we want command-line parameters to overwrite the GUI settings.
192194
for (OptionID option : {DatabaseCache, ThreadsScriptVerif, SpendZeroConfChange, ExternalSignerPath, MapPortUPnP,
193-
MapPortNatpmp, Listen, Server, Prune, ProxyUse, ProxyUseTor}) {
195+
MapPortNatpmp, Listen, Server, Prune, ProxyUse, ProxyUseTor, Language}) {
194196
std::string setting = SettingName(option);
195197
if (node().isSettingIgnored(setting)) addOverriddenOption("-" + setting);
196198
try {
@@ -204,9 +206,6 @@ bool OptionsModel::Init(bilingual_str& error)
204206
}
205207

206208
// If setting doesn't exist create it with defaults.
207-
//
208-
// If gArgs.SoftSetArg() or gArgs.SoftSetBoolArg() return false we were overridden
209-
// by command-line and show this in the UI.
210209

211210
// Main
212211
if (!settings.contains("strDataDir"))
@@ -221,13 +220,6 @@ bool OptionsModel::Init(bilingual_str& error)
221220
#endif
222221

223222
// Display
224-
if (!settings.contains("language"))
225-
settings.setValue("language", "");
226-
if (!gArgs.SoftSetArg("-lang", settings.value("language").toString().toStdString()))
227-
addOverriddenOption("-lang");
228-
229-
language = settings.value("language").toString();
230-
231223
if (!settings.contains("UseEmbeddedMonospacedFont")) {
232224
settings.setValue("UseEmbeddedMonospacedFont", "true");
233225
}
@@ -420,7 +412,7 @@ QVariant OptionsModel::getOption(OptionID option) const
420412
case ThirdPartyTxUrls:
421413
return strThirdPartyTxUrls;
422414
case Language:
423-
return settings.value("language");
415+
return QString::fromStdString(SettingToString(setting(), ""));
424416
case UseEmbeddedMonospacedFont:
425417
return m_use_embedded_monospaced_font;
426418
case CoinControlFeatures:
@@ -563,8 +555,8 @@ bool OptionsModel::setOption(OptionID option, const QVariant& value)
563555
}
564556
break;
565557
case Language:
566-
if (settings.value("language") != value) {
567-
settings.setValue("language", value);
558+
if (changed()) {
559+
update(value.toString().toStdString());
568560
setRestartRequired(true);
569561
}
570562
break;
@@ -715,6 +707,7 @@ void OptionsModel::checkAndMigrate()
715707
migrate_setting(ProxyUse, "fUseProxy");
716708
migrate_setting(ProxyIPTor, "addrSeparateProxyTor");
717709
migrate_setting(ProxyUseTor, "fUseSeparateProxyTor");
710+
migrate_setting(Language, "language");
718711

719712
// In case migrating QSettings caused any settings value to change, rerun
720713
// parameter interaction code to update other settings. This is particularly

0 commit comments

Comments
 (0)