parent
e8739c50fb
commit
b3597f8fca
@ -1,72 +0,0 @@
|
|||||||
commit 7ac27098cf9c03fa02d9bac4536f7d6ee3159e42
|
|
||||||
Author: Simon Quigley <simon@tsimonq2.net>
|
|
||||||
Date: Sat Dec 23 17:53:11 2023 -0600
|
|
||||||
|
|
||||||
Don't default to C, and be somewhat reasonable about locales, to start.
|
|
||||||
|
|
||||||
diff --git a/src/installerprompt.cpp b/src/installerprompt.cpp
|
|
||||||
index 04bc415..87a20c3 100644
|
|
||||||
--- a/src/installerprompt.cpp
|
|
||||||
+++ b/src/installerprompt.cpp
|
|
||||||
@@ -376,10 +376,15 @@ QString InstallerPrompt::getDisplayNameForLocale(const QLocale &locale) {
|
|
||||||
return s;
|
|
||||||
};
|
|
||||||
|
|
||||||
+ QLocale currentAppLocale = QLocale::system();
|
|
||||||
QString nativeName = locale.nativeLanguageName();
|
|
||||||
QString nativeCountryName = sanitize(locale.nativeCountryName());
|
|
||||||
- QString englishLanguageName = QLocale::languageToString(locale.language());
|
|
||||||
- QString englishCountryName = sanitize(QLocale::countryToString(locale.country()));
|
|
||||||
+ QString englishLanguageName = currentAppLocale.languageToString(locale.language());
|
|
||||||
+ QString englishCountryName = sanitize(currentAppLocale.countryToString(locale.country()));
|
|
||||||
+
|
|
||||||
+ if (nativeName.isEmpty() || nativeCountryName.isEmpty()) {
|
|
||||||
+ return QString();
|
|
||||||
+ }
|
|
||||||
|
|
||||||
// Rename "American English" to "English"
|
|
||||||
if (locale.language() == QLocale::English) {
|
|
||||||
@@ -419,31 +424,29 @@ void InstallerPrompt::initLanguageComboBox() {
|
|
||||||
}
|
|
||||||
|
|
||||||
QStringList InstallerPrompt::getAvailableLanguages() {
|
|
||||||
- QMap<QString, QString> languageMap; // Default sorting by QString is case-sensitive
|
|
||||||
-
|
|
||||||
- for (int language = QLocale::C; language <= QLocale::LastLanguage; ++language) {
|
|
||||||
- foreach (int country, QLocale::countriesForLanguage(static_cast<QLocale::Language>(language))) {
|
|
||||||
- QLocale locale(static_cast<QLocale::Language>(language), static_cast<QLocale::Country>(country));
|
|
||||||
+ QMap<QString, QString> language_map; // Default sorting by QString is case-sensitive
|
|
||||||
|
|
||||||
- QString displayName = getDisplayNameForLocale(locale);
|
|
||||||
- if (displayName.isEmpty()) continue;
|
|
||||||
+ QList<QLocale> all_locales = QLocale::matchingLocales(QLocale::AnyLanguage, QLocale::AnyScript, QLocale::AnyCountry);
|
|
||||||
+ for (const QLocale &locale : all_locales) {
|
|
||||||
+ QString display_name = getDisplayNameForLocale(locale);
|
|
||||||
+ if (display_name.isEmpty()) continue;
|
|
||||||
|
|
||||||
- languageMap.insert(displayName, locale.name());
|
|
||||||
- }
|
|
||||||
+ language_map.insert(display_name, locale.name());
|
|
||||||
}
|
|
||||||
+
|
|
||||||
// Sort the language display names
|
|
||||||
- QStringList sortedLanguages = languageMap.keys();
|
|
||||||
- std::sort(sortedLanguages.begin(), sortedLanguages.end(), [](const QString &a, const QString &b) {
|
|
||||||
+ QStringList sorted_languages = language_map.keys();
|
|
||||||
+ std::sort(sorted_languages.begin(), sorted_languages.end(), [](const QString &a, const QString &b) {
|
|
||||||
return a.compare(b, Qt::CaseInsensitive) < 0;
|
|
||||||
});
|
|
||||||
|
|
||||||
// Clear the existing languageLocaleMap and repopulate it based on sortedLanguages
|
|
||||||
languageLocaleMap.clear();
|
|
||||||
- for (const QString &languageName : sortedLanguages) {
|
|
||||||
- languageLocaleMap.insert(languageName, languageMap[languageName]);
|
|
||||||
+ for (const QString &language_name : sorted_languages) {
|
|
||||||
+ languageLocaleMap.insert(language_name, language_map[language_name]);
|
|
||||||
}
|
|
||||||
|
|
||||||
- return sortedLanguages;
|
|
||||||
+ return sorted_languages;
|
|
||||||
}
|
|
||||||
|
|
||||||
void InstallerPrompt::onLanguageChanged(int index) {
|
|
@ -1 +0,0 @@
|
|||||||
c-fixes.patch
|
|
Loading…
Reference in new issue