summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2013-10-10 12:26:03 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-10-10 13:00:23 -0700
commit8bd26af44e03d20659ac76f927479713e14fad15 (patch)
tree45e236414e1f746a4a16cca70d871d5fced998cb
parent3b691d5d6e9e4f90cac806cccc151637f13c4ad5 (diff)
downloadsubsurface-8bd26af44e03d20659ac76f927479713e14fad15.tar.gz
Work around a Qt Locale bug on Mac
With Qt4.8.5 Locale::uiLanguages() sometimes doesn't return the country, just the language. This works around this by recreating the locale if this has happened. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-gui.cpp14
1 files changed, 11 insertions, 3 deletions
diff --git a/qt-gui.cpp b/qt-gui.cpp
index e0cff0b2b..30afebed9 100644
--- a/qt-gui.cpp
+++ b/qt-gui.cpp
@@ -87,21 +87,29 @@ void init_ui(int *argcp, char ***argvp)
xslt_path = strdup(getSubsurfaceDataPath("xslt").toAscii().data());
QLocale loc;
+ QString uiLang = loc.uiLanguages().first();
+ // there's a stupid Qt bug on MacOS where uiLanguages doesn't give us the country info
+ if (!uiLang.contains('-') && uiLang != loc.bcp47Name()) {
+ QLocale loc2(loc.bcp47Name());
+ loc = loc2;
+ uiLang = loc2.uiLanguages().first();
+ }
+
// we don't have translations for English - if we don't check for this
// Qt will proceed to load the second language in preference order - not what we want
// on Linux this tends to be en-US, but on the Mac it's just en
- if (!loc.uiLanguages().first().startsWith("en")) {
+ if (!uiLang.startsWith("en")) {
qtTranslator = new QTranslator;
if (qtTranslator->load(loc,"qt", "_", QLibraryInfo::location(QLibraryInfo::TranslationsPath))) {
application->installTranslator(qtTranslator);
} else {
- qDebug() << "can't find Qt localization for locale" << loc.uiLanguages().first();
+ qDebug() << "can't find Qt localization for locale" << uiLang;
}
ssrfTranslator = new QTranslator;
if (ssrfTranslator->load(loc,"subsurface", "_")) {
application->installTranslator(ssrfTranslator);
} else {
- qDebug() << "can't find Subsurface localization for locale" << loc.uiLanguages().first();
+ qDebug() << "can't find Subsurface localization for locale" << uiLang;
}
}