summaryrefslogtreecommitdiffstats
path: root/src/corelib/tools
diff options
context:
space:
mode:
authorcon <qtc-committer@nokia.com>2009-09-18 12:20:00 (GMT)
committercon <qtc-committer@nokia.com>2009-09-18 12:22:54 (GMT)
commit734f815a9325ad472517cd5ef869d6081eb89661 (patch)
tree57de9bf4746e8cd27c14d2fbcbf423395ac0a622 /src/corelib/tools
parentad32d9a2d2c3b1202867f8563a69afb93effecd0 (diff)
downloadQt-734f815a9325ad472517cd5ef869d6081eb89661.zip
Qt-734f815a9325ad472517cd5ef869d6081eb89661.tar.gz
Qt-734f815a9325ad472517cd5ef869d6081eb89661.tar.bz2
System locale on Mac may not return AnyCountry for any language != C
Because of QLocale limitations this broke other places. Reviewed-by: Denis Dzyubenko
Diffstat (limited to 'src/corelib/tools')
-rw-r--r--src/corelib/tools/qlocale.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/corelib/tools/qlocale.cpp b/src/corelib/tools/qlocale.cpp
index a1f0712..136bafa 100644
--- a/src/corelib/tools/qlocale.cpp
+++ b/src/corelib/tools/qlocale.cpp
@@ -1216,9 +1216,12 @@ QVariant QSystemLocale::query(QueryType type, QVariant in = QVariant()) const
QString preferredLanguage;
QString preferredCountry;
getMacPreferredLanguageAndCountry(&preferredLanguage, &preferredCountry);
+ QLocale::Language languageCode = (preferredLanguage.isEmpty() ? QLocale::C : codeToLanguage(preferredLanguage.data()));
+ QLocale::Country countryCode = (preferredCountry.isEmpty() ? QLocale::AnyCountry : codeToCountry(preferredCountry.data()));
+ const QLocalePrivate *d = findLocale(languageCode, countryCode);
if (type == LanguageId)
- return codeToLanguage(preferredLanguage.data());
- return codeToCountry(preferredCountry.data());
+ return (QLocale::Language)d->languageId();
+ return (QLocale::Country)d->countryId();
}
case MeasurementSystem: