LeOSium_webview/LeOS/patches/Override-Navigator-Language...

78 lines
3.6 KiB
Diff

From: uazo <uazo@users.noreply.github.com>
Date: Fri, 2 Sep 2022 07:44:58 +0000
Subject: Override Navigator Language
Uses the first of the accept-languages as the system language for blink
and fix the selection in the UI for the browser language
Original License: GPL-2.0-or-later - https://spdx.org/licenses/GPL-2.0-or-later.html
License: GPL-3.0-only - https://spdx.org/licenses/GPL-3.0-only.html
---
.../browser/language/AppLocaleUtils.java | 20 +++++++++++++++++++
.../renderer_host/render_process_host_impl.cc | 6 +++++-
2 files changed, 25 insertions(+), 1 deletion(-)
diff --git a/chrome/browser/language/android/java/src/org/chromium/chrome/browser/language/AppLocaleUtils.java b/chrome/browser/language/android/java/src/org/chromium/chrome/browser/language/AppLocaleUtils.java
--- a/chrome/browser/language/android/java/src/org/chromium/chrome/browser/language/AppLocaleUtils.java
+++ b/chrome/browser/language/android/java/src/org/chromium/chrome/browser/language/AppLocaleUtils.java
@@ -34,6 +34,10 @@ import java.util.Locale;
public class AppLocaleUtils {
private AppLocaleUtils(){};
+ public interface InstallListener {
+ void onComplete(boolean success);
+ }
+
// Value of AppLocale preference when the system language is used.
public static final String APP_LOCALE_USE_SYSTEM_LANGUAGE = null;
@@ -98,6 +102,22 @@ public class AppLocaleUtils {
return locale.toLanguageTag();
}
+ public static void setAppLanguagePref(
+ String languageName, InstallListener listener) {
+ InstallListener wrappedListener = (success) -> {
+ if (success) {
+ if (shouldUseSystemManagedLocale()) {
+ setSystemManagedAppLanguage(languageName);
+ } else {
+ SharedPreferencesManager.getInstance().writeString(
+ ChromePreferenceKeys.APPLICATION_OVERRIDE_LANGUAGE, languageName);
+ }
+ }
+ listener.onComplete(success);
+ };
+ wrappedListener.onComplete(true);
+ }
+
/**
* Gets the first original system locale from {@link LocaleManager}. This is the language that
* Chrome would use if there was no override set. If there are no possible UI languages en-US is
diff --git a/content/browser/renderer_host/render_process_host_impl.cc b/content/browser/renderer_host/render_process_host_impl.cc
--- a/content/browser/renderer_host/render_process_host_impl.cc
+++ b/content/browser/renderer_host/render_process_host_impl.cc
@@ -68,6 +68,7 @@
#include "cc/base/switches.h"
#include "components/discardable_memory/public/mojom/discardable_shared_memory_manager.mojom.h"
#include "components/discardable_memory/service/discardable_shared_memory_manager.h"
+#include "components/language/core/browser/language_prefs.h"
#include "components/metrics/single_sample_metrics.h"
#include "components/services/storage/privileged/mojom/indexed_db_control.mojom.h"
#include "components/services/storage/public/cpp/buckets/bucket_id.h"
@@ -3217,8 +3218,11 @@ void RenderProcessHostImpl::AppendRendererCommandLine(
PropagateBrowserCommandLineToRenderer(browser_command_line, command_line);
// Pass on the browser locale.
- const std::string locale =
+ std::string locale =
GetContentClient()->browser()->GetApplicationLocale();
+ const std::string accept_langs = GetContentClient()->browser()->GetAcceptLangs(browser_context_);
+ if (!accept_langs.empty())
+ locale = language::GetFirstLanguage(accept_langs);
command_line->AppendSwitchASCII(switches::kLang, locale);
// A non-empty RendererCmdPrefix implies that Zygote is disabled.
--
2.25.1