summaryrefslogtreecommitdiff
path: root/desktop/source/app/langselect.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'desktop/source/app/langselect.cxx')
-rw-r--r--desktop/source/app/langselect.cxx26
1 files changed, 8 insertions, 18 deletions
diff --git a/desktop/source/app/langselect.cxx b/desktop/source/app/langselect.cxx
index db8d0df754c8..085e0a74a1d0 100644
--- a/desktop/source/app/langselect.cxx
+++ b/desktop/source/app/langselect.cxx
@@ -105,16 +105,6 @@ static OUString locateSofficeIniFile()
return aSofficeIniFileURL;
}
-Locale LanguageSelection::IsoStringToLocale(const OUString& str)
-{
- Locale l;
- sal_Int32 index=0;
- l.Language = str.getToken(0, '-', index);
- if (index >= 0) l.Country = str.getToken(0, '-', index);
- if (index >= 0) l.Variant = str.getToken(0, '-', index);
- return l;
-}
-
bool LanguageSelection::prepareLanguage()
{
m_eStatus = LS_STATUS_OK;
@@ -200,11 +190,11 @@ bool LanguageSelection::prepareLanguage()
{
try
{
- // prepare default config provider by localizing it to the selected locale
- // this will ensure localized configuration settings to be selected accoring to the
- // UI language.
- Locale loc = LanguageSelection::IsoStringToLocale(aLocaleString);
- theConfigProvider->setLocale(loc);
+ // prepare default config provider by localizing it to the selected
+ // locale this will ensure localized configuration settings to be
+ // selected according to the UI language.
+ LanguageTag aUILanguageTag(aLocaleString);
+ theConfigProvider->setLocale(aUILanguageTag.getLocale( false));
Reference< XPropertySet > xProp(getConfigAccess("org.openoffice.Setup/L10N/", sal_True), UNO_QUERY_THROW);
if ( !bCmdLanguage )
@@ -222,14 +212,14 @@ bool LanguageSelection::prepareLanguage()
Reference< XChangesBatch >(xProp2, UNO_QUERY_THROW)->commitChanges();
}
- MsLangId::setConfiguredSystemUILanguage( LanguageTag(loc).getLanguageType( false) );
+ MsLangId::setConfiguredSystemUILanguage( aUILanguageTag.getLanguageType( false) );
OUString sLocale;
xProp->getPropertyValue(OUString(RTL_CONSTASCII_USTRINGPARAM("ooSetupSystemLocale"))) >>= sLocale;
if ( !sLocale.isEmpty() )
{
- loc = LanguageSelection::IsoStringToLocale(sLocale);
- MsLangId::setConfiguredSystemLanguage( LanguageTag(loc).getLanguageType( false) );
+ LanguageTag aLocaleLanguageTag(sLocale);
+ MsLangId::setConfiguredSystemLanguage( aLocaleLanguageTag.getLanguageType( false) );
}
else
MsLangId::setConfiguredSystemLanguage( MsLangId::getSystemLanguage() );