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.cxx47
1 files changed, 5 insertions, 42 deletions
diff --git a/desktop/source/app/langselect.cxx b/desktop/source/app/langselect.cxx
index a8309e5987ba..9b52d8a42fe9 100644
--- a/desktop/source/app/langselect.cxx
+++ b/desktop/source/app/langselect.cxx
@@ -49,28 +49,6 @@ namespace {
OUString foundLocale;
-OUString getInstalledLocale(
- css::uno::Sequence<OUString> const & installed, OUString const & locale)
-{
- if (locale.isEmpty())
- return OUString(); // do not attempt to resolve anything
-
- for (sal_Int32 i = 0; i != installed.getLength(); ++i) {
- if (installed[i] == locale) {
- return installed[i];
- }
- }
- ::std::vector<OUString> fallbacks( LanguageTag( locale).getFallbackStrings( false));
- for (OUString & rf : fallbacks) {
- for (sal_Int32 i = 0; i != installed.getLength(); ++i) {
- if (installed[i] == rf) {
- return installed[i];
- }
- }
- }
- return OUString();
-}
-
void setMsLangIdFallback(OUString const & locale) {
// #i32939# setting of default document language
// See #i42730# for rules for determining source of settings
@@ -101,24 +79,16 @@ OUString getEmergencyLocale() {
officecfg::Setup::Office::InstalledLocales::get()->
getElementNames());
OUString locale(
- getInstalledLocale(
+ getInstalledLocaleForLanguage(
inst,
officecfg::Office::Linguistic::General::UILocale::get()));
if (!locale.isEmpty()) {
return locale;
}
- locale = getInstalledLocale(
- inst, officecfg::System::L10N::UILocale::get());
- if (!locale.isEmpty()) {
- return locale;
- }
- locale = getInstalledLocale(inst, "en-US");
+ locale = getInstalledLocaleForSystemUILanguage(inst);
if (!locale.isEmpty()) {
return locale;
}
- if (inst.hasElements()) {
- return inst[0];
- }
} catch (css::uno::Exception & e) {
SAL_WARN("desktop.app", "ignoring Exception \"" << e.Message << "\"");
}
@@ -135,7 +105,7 @@ bool prepareLocale() {
officecfg::Setup::Office::InstalledLocales::get()->getElementNames());
OUString locale(officecfg::Office::Linguistic::General::UILocale::get());
if (!locale.isEmpty()) {
- locale = getInstalledLocale(inst, locale);
+ locale = getInstalledLocaleForLanguage(inst, locale);
if (locale.isEmpty()) {
// Selected language is not/no longer installed:
try {
@@ -153,21 +123,14 @@ bool prepareLocale() {
}
bool cmdLanguage = false;
if (locale.isEmpty()) {
- locale = getInstalledLocale(
+ locale = getInstalledLocaleForLanguage(
inst, Desktop::GetCommandLineArgs().GetLanguage());
if (!locale.isEmpty()) {
cmdLanguage = true;
}
}
if (locale.isEmpty()) {
- locale = getInstalledLocale(
- inst, officecfg::System::L10N::UILocale::get());
- }
- if (locale.isEmpty()) {
- locale = getInstalledLocale(inst, "en-US");
- }
- if (locale.isEmpty() && inst.hasElements()) {
- locale = inst[0];
+ locale = getInstalledLocaleForSystemUILanguage(inst);
}
if (locale.isEmpty()) {
return false;