Index: chrome/browser/dom_ui/options/language_options_handler.cc |
=================================================================== |
--- chrome/browser/dom_ui/options/language_options_handler.cc (revision 71884) |
+++ chrome/browser/dom_ui/options/language_options_handler.cc (working copy) |
@@ -2,10 +2,6 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-// TODO(csilv): This is for the move CL. Changes to make this cross-platform |
-// will come in the followup CL. |
-#if defined(OS_CHROMEOS) |
- |
#include "chrome/browser/dom_ui/options/language_options_handler.h" |
#include <map> |
@@ -16,23 +12,27 @@ |
#include "app/l10n_util.h" |
#include "base/basictypes.h" |
+#include "base/command_line.h" |
#include "base/utf_string_conversions.h" |
#include "base/values.h" |
#include "chrome/app/chrome_command_ids.h" |
+#include "chrome/browser/browser_list.h" |
#include "chrome/browser/browser_process.h" |
-#include "chrome/browser/chromeos/cros/cros_library.h" |
-#include "chrome/browser/chromeos/cros/input_method_library.h" |
-#include "chrome/browser/chromeos/input_method/input_method_util.h" |
#include "chrome/browser/metrics/user_metrics.h" |
+#include "chrome/browser/prefs/pref_service.h" |
#include "chrome/browser/profiles/profile.h" |
#include "chrome/browser/tab_contents/tab_contents.h" |
#include "chrome/browser/ui/browser.h" |
+#include "chrome/common/chrome_switches.h" |
#include "chrome/common/pref_names.h" |
#include "chrome/common/spellcheck_common.h" |
#include "grit/chromium_strings.h" |
#include "grit/generated_resources.h" |
-namespace chromeos { |
+#if defined(OS_CHROMEOS) |
+#include "chrome/browser/chromeos/cros/cros_library.h" |
+#include "chrome/browser/chromeos/cros/input_method_library.h" |
+#endif |
LanguageOptionsHandler::LanguageOptionsHandler() { |
} |
@@ -43,60 +43,42 @@ |
void LanguageOptionsHandler::GetLocalizedValues( |
DictionaryValue* localized_strings) { |
DCHECK(localized_strings); |
+ string16 product_name; |
+#if defined(OS_CHROMEOS) |
+ product_name = l10n_util::GetStringUTF16(IDS_PRODUCT_OS_NAME); |
+#else |
+ product_name = l10n_util::GetStringUTF16(IDS_PRODUCT_NAME); |
+#endif |
localized_strings->SetString("languagePage", |
l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_DIALOG_TITLE)); |
localized_strings->SetString("add_button", |
l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_ADD_BUTTON)); |
- localized_strings->SetString("configure", |
- l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_CONFIGURE)); |
- localized_strings->SetString("input_method", |
- l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_INPUT_METHOD)); |
localized_strings->SetString("languages", |
l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_LANGUAGES)); |
- localized_strings->SetString("please_add_another_input_method", |
- l10n_util::GetStringUTF16( |
- IDS_OPTIONS_SETTINGS_LANGUAGES_PLEASE_ADD_ANOTHER_INPUT_METHOD)); |
localized_strings->SetString("please_add_another_language", |
l10n_util::GetStringUTF16( |
IDS_OPTIONS_SETTINGS_LANGUAGES_PLEASE_ADD_ANOTHER_LANGUAGE)); |
- localized_strings->SetString("ok_button", l10n_util::GetStringUTF16(IDS_OK)); |
localized_strings->SetString("remove_button", |
l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_REMOVE_BUTTON)); |
- localized_strings->SetString("sign_out_button", |
- l10n_util::GetStringUTF16( |
- IDS_OPTIONS_SETTINGS_LANGUAGES_SIGN_OUT_BUTTON)); |
localized_strings->SetString("add_language_instructions", |
l10n_util::GetStringUTF16( |
IDS_OPTIONS_SETTINGS_LANGUAGES_ADD_LANGUAGE_INSTRUCTIONS)); |
- localized_strings->SetString("input_method_instructions", |
- l10n_util::GetStringUTF16( |
- IDS_OPTIONS_SETTINGS_LANGUAGES_INPUT_METHOD_INSTRUCTIONS)); |
- localized_strings->SetString("switch_input_methods_hint", |
- l10n_util::GetStringFUTF16( |
- IDS_OPTIONS_SETTINGS_LANGUAGES_SWITCH_INPUT_METHODS_HINT, |
- ASCIIToUTF16("alt+shift"))); |
- localized_strings->SetString("select_previous_input_method_hint", |
- l10n_util::GetStringFUTF16( |
- IDS_OPTIONS_SETTINGS_LANGUAGES_SELECT_PREVIOUS_INPUT_METHOD_HINT, |
- ASCIIToUTF16("ctrl+space"))); |
localized_strings->SetString("cannot_be_displayed_in_this_language", |
l10n_util::GetStringFUTF16( |
IDS_OPTIONS_SETTINGS_LANGUAGES_CANNOT_BE_DISPLAYED_IN_THIS_LANGUAGE, |
- l10n_util::GetStringUTF16(IDS_PRODUCT_OS_NAME))); |
+ product_name)); |
localized_strings->SetString("is_displayed_in_this_language", |
l10n_util::GetStringFUTF16( |
IDS_OPTIONS_SETTINGS_LANGUAGES_IS_DISPLAYED_IN_THIS_LANGUAGE, |
- l10n_util::GetStringUTF16(IDS_PRODUCT_OS_NAME))); |
+ product_name)); |
localized_strings->SetString("display_in_this_language", |
l10n_util::GetStringFUTF16( |
IDS_OPTIONS_SETTINGS_LANGUAGES_DISPLAY_IN_THIS_LANGUAGE, |
- l10n_util::GetStringUTF16(IDS_PRODUCT_OS_NAME))); |
- localized_strings->SetString("sign_out_required", |
- l10n_util::GetStringUTF16(IDS_OPTIONS_RESTART_REQUIRED)); |
+ product_name)); |
localized_strings->SetString("this_language_is_currently_in_use", |
l10n_util::GetStringFUTF16( |
IDS_OPTIONS_SETTINGS_LANGUAGES_THIS_LANGUAGE_IS_CURRENTLY_IN_USE, |
- l10n_util::GetStringUTF16(IDS_PRODUCT_OS_NAME))); |
+ product_name)); |
localized_strings->SetString("use_this_for_spell_checking", |
l10n_util::GetStringUTF16( |
IDS_OPTIONS_SETTINGS_USE_THIS_FOR_SPELL_CHECKING)); |
@@ -106,23 +88,73 @@ |
localized_strings->SetString("is_used_for_spell_checking", |
l10n_util::GetStringUTF16( |
IDS_OPTIONS_SETTINGS_IS_USED_FOR_SPELL_CHECKING)); |
+ localized_strings->SetString("restart_required", |
+ l10n_util::GetStringUTF16(IDS_OPTIONS_RESTART_REQUIRED)); |
+ localized_strings->SetString("enable_spell_check", |
+ l10n_util::GetStringUTF16(IDS_OPTIONS_ENABLE_SPELLCHECK)); |
+ localized_strings->SetString("enable_auto_spell_correction", |
+ l10n_util::GetStringUTF16(IDS_OPTIONS_ENABLE_AUTO_SPELL_CORRECTION)); |
+ localized_strings->SetString("add_language_title", |
+ l10n_util::GetStringUTF16(IDS_OPTIONS_LANGUAGES_ADD_TITLE)); |
+ localized_strings->SetString("add_language_select_label", |
+ l10n_util::GetStringUTF16(IDS_OPTIONS_LANGUAGES_ADD_SELECT_LABEL)); |
- // GetSupportedInputMethods() never return NULL. |
- scoped_ptr<InputMethodDescriptors> descriptors( |
- CrosLibrary::Get()->GetInputMethodLibrary()->GetSupportedInputMethods()); |
+#if defined(OS_CHROMEOS) |
+ localized_strings->SetString("ok_button", l10n_util::GetStringUTF16(IDS_OK)); |
+ localized_strings->SetString("configure", |
+ l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_CONFIGURE)); |
+ localized_strings->SetString("input_method", |
+ l10n_util::GetStringUTF16(IDS_OPTIONS_SETTINGS_LANGUAGES_INPUT_METHOD)); |
+ localized_strings->SetString("please_add_another_input_method", |
+ l10n_util::GetStringUTF16( |
+ IDS_OPTIONS_SETTINGS_LANGUAGES_PLEASE_ADD_ANOTHER_INPUT_METHOD)); |
+ localized_strings->SetString("input_method_instructions", |
+ l10n_util::GetStringUTF16( |
+ IDS_OPTIONS_SETTINGS_LANGUAGES_INPUT_METHOD_INSTRUCTIONS)); |
+ localized_strings->SetString("switch_input_methods_hint", |
+ l10n_util::GetStringFUTF16( |
+ IDS_OPTIONS_SETTINGS_LANGUAGES_SWITCH_INPUT_METHODS_HINT, |
+ ASCIIToUTF16("alt+shift"))); |
+ localized_strings->SetString("select_previous_input_method_hint", |
+ l10n_util::GetStringFUTF16( |
+ IDS_OPTIONS_SETTINGS_LANGUAGES_SELECT_PREVIOUS_INPUT_METHOD_HINT, |
+ ASCIIToUTF16("ctrl+space"))); |
+ localized_strings->SetString("restart_button", |
+ l10n_util::GetStringUTF16( |
+ IDS_OPTIONS_SETTINGS_LANGUAGES_SIGN_OUT_BUTTON)); |
+#else |
+ localized_strings->SetString("restart_button", |
+ l10n_util::GetStringUTF16( |
+ IDS_OPTIONS_SETTINGS_LANGUAGES_RESTART_BUTTON)); |
+#endif |
// The followigns are resources, rather than local strings. |
localized_strings->SetString("currentUiLanguageCode", |
- g_browser_process->GetApplicationLocale()); |
- localized_strings->Set("inputMethodList", GetInputMethodList(*descriptors)); |
- localized_strings->Set("languageList", GetLanguageList(*descriptors)); |
+ g_browser_process->GetApplicationLocale()); |
localized_strings->Set("spellCheckLanguageCodeSet", |
GetSpellCheckLanguageCodeSet()); |
localized_strings->Set("uiLanguageCodeSet", GetUiLanguageCodeSet()); |
+ |
+ const CommandLine& command_line = *CommandLine::ForCurrentProcess(); |
+ bool experimental_spell_check_features = |
+ command_line.HasSwitch(switches::kExperimentalSpellcheckerFeatures); |
+ localized_strings->SetString("experimentalSpellCheckFeatures", |
+ experimental_spell_check_features ? "true" : "false"); |
+ |
+#if defined(OS_CHROMEOS) |
+ // GetSupportedInputMethods() never return NULL. |
+ scoped_ptr<chromeos::InputMethodDescriptors> descriptors( |
+ chromeos::CrosLibrary::Get()->GetInputMethodLibrary()->GetSupportedInputMethods()); |
James Hawkins
2011/01/20 03:11:08
80cols.
csilv
2011/01/20 20:09:55
Done.
|
+ localized_strings->Set("languageList", GetLanguageList(*descriptors)); |
+ localized_strings->Set("inputMethodList", GetInputMethodList(*descriptors)); |
+#else |
+ localized_strings->Set("languageList", GetLanguageList()); |
+#endif |
} |
void LanguageOptionsHandler::RegisterMessages() { |
DCHECK(dom_ui_); |
+#if defined(OS_CHROMEOS) |
dom_ui_->RegisterMessageCallback("inputMethodDisable", |
NewCallback(this, &LanguageOptionsHandler::InputMethodDisableCallback)); |
dom_ui_->RegisterMessageCallback("inputMethodEnable", |
@@ -130,6 +162,7 @@ |
dom_ui_->RegisterMessageCallback("inputMethodOptionsOpen", |
NewCallback(this, |
&LanguageOptionsHandler::InputMethodOptionsOpenCallback)); |
+#endif |
dom_ui_->RegisterMessageCallback("languageOptionsOpen", |
NewCallback(this, &LanguageOptionsHandler::LanguageOptionsOpenCallback)); |
dom_ui_->RegisterMessageCallback("spellCheckLanguageChange", |
@@ -137,20 +170,21 @@ |
&LanguageOptionsHandler::SpellCheckLanguageChangeCallback)); |
dom_ui_->RegisterMessageCallback("uiLanguageChange", |
NewCallback(this, &LanguageOptionsHandler::UiLanguageChangeCallback)); |
- dom_ui_->RegisterMessageCallback("uiLanguageSignOut", |
- NewCallback(this, &LanguageOptionsHandler::SignOutCallback)); |
+ dom_ui_->RegisterMessageCallback("uiLanguageRestart", |
+ NewCallback(this, &LanguageOptionsHandler::RestartCallback)); |
} |
+#if defined(OS_CHROMEOS) |
ListValue* LanguageOptionsHandler::GetInputMethodList( |
- const InputMethodDescriptors& descriptors) { |
+ const chromeos::InputMethodDescriptors& descriptors) { |
ListValue* input_method_list = new ListValue(); |
for (size_t i = 0; i < descriptors.size(); ++i) { |
- const InputMethodDescriptor& descriptor = descriptors[i]; |
+ const chromeos::InputMethodDescriptor& descriptor = descriptors[i]; |
const std::string language_code = |
- input_method::GetLanguageCodeFromDescriptor(descriptor); |
+ chromeos::input_method::GetLanguageCodeFromDescriptor(descriptor); |
const std::string display_name = |
- input_method::GetInputMethodDisplayNameFromId(descriptor.id); |
+ chromeos::input_method::GetInputMethodDisplayNameFromId(descriptor.id); |
DictionaryValue* dictionary = new DictionaryValue(); |
dictionary->SetString("id", descriptor.id); |
@@ -162,11 +196,12 @@ |
language_codes->SetBoolean(language_code, true); |
// Check kExtraLanguages to see if there are languages associated with |
// this input method. If these are present, add these. |
- for (size_t j = 0; j < arraysize(input_method::kExtraLanguages); ++j) { |
+ for (size_t j = 0; j < arraysize(chromeos::input_method::kExtraLanguages); |
+ ++j) { |
const std::string extra_input_method_id = |
- input_method::kExtraLanguages[j].input_method_id; |
+ chromeos::input_method::kExtraLanguages[j].input_method_id; |
const std::string extra_language_code = |
- input_method::kExtraLanguages[j].language_code; |
+ chromeos::input_method::kExtraLanguages[j].language_code; |
if (extra_input_method_id == descriptor.id) { |
language_codes->SetBoolean(extra_language_code, true); |
} |
@@ -180,19 +215,20 @@ |
} |
ListValue* LanguageOptionsHandler::GetLanguageList( |
- const InputMethodDescriptors& descriptors) { |
+ const chromeos::InputMethodDescriptors& descriptors) { |
std::set<std::string> language_codes; |
// Collect the language codes from the supported input methods. |
for (size_t i = 0; i < descriptors.size(); ++i) { |
- const InputMethodDescriptor& descriptor = descriptors[i]; |
+ const chromeos::InputMethodDescriptor& descriptor = descriptors[i]; |
const std::string language_code = |
- input_method::GetLanguageCodeFromDescriptor(descriptor); |
+ chromeos::input_method::GetLanguageCodeFromDescriptor(descriptor); |
language_codes.insert(language_code); |
} |
// Collect the language codes from kExtraLanguages. |
- for (size_t i = 0; i < arraysize(input_method::kExtraLanguages); ++i) { |
+ for (size_t i = 0; i < arraysize(chromeos::input_method::kExtraLanguages); |
+ ++i) { |
const char* language_code = |
- input_method::kExtraLanguages[i].language_code; |
+ chromeos::input_method::kExtraLanguages[i].language_code; |
language_codes.insert(language_code); |
} |
@@ -210,9 +246,9 @@ |
for (std::set<std::string>::const_iterator iter = language_codes.begin(); |
iter != language_codes.end(); ++iter) { |
const string16 display_name = |
- input_method::GetLanguageDisplayNameFromCode(*iter); |
+ chromeos::input_method::GetLanguageDisplayNameFromCode(*iter); |
const string16 native_display_name = |
- input_method::GetLanguageNativeDisplayNameFromCode(*iter); |
+ chromeos::input_method::GetLanguageNativeDisplayNameFromCode(*iter); |
display_names.push_back(display_name); |
language_map[display_name] = |
std::make_pair(*iter, native_display_name); |
@@ -236,7 +272,56 @@ |
return language_list; |
} |
+#endif |
+#if !defined(OS_CHROMEOS) |
+ListValue* LanguageOptionsHandler::GetLanguageList() { |
+ // Collect the language codes from the supported accept-languages. |
+ const std::string app_locale = g_browser_process->GetApplicationLocale(); |
+ std::vector<std::string> language_codes; |
+ l10n_util::GetAcceptLanguagesForLocale(app_locale, &language_codes); |
+ |
+ // Map of display name -> {language code, native_display_name}. |
+ // In theory, we should be able to create a map that is sorted by |
+ // display names using ICU comparator, but doing it is hard, thus we'll |
+ // use an auxiliary vector to achieve the same result. |
+ typedef std::pair<std::string, string16> LanguagePair; |
+ typedef std::map<string16, LanguagePair> LanguageMap; |
+ LanguageMap language_map; |
+ // The auxiliary vector mentioned above. |
+ std::vector<string16> display_names; |
+ |
+ // Build the list of display names, and build the language map. |
+ for (size_t i = 0; i < language_codes.size(); ++i) { |
+ const string16 display_name = |
+ l10n_util::GetDisplayNameForLocale(language_codes[i], app_locale, true); |
+ const string16 native_display_name = |
+ l10n_util::GetDisplayNameForLocale(language_codes[i], language_codes[i], |
+ true); |
+ display_names.push_back(display_name); |
+ language_map[display_name] = |
+ std::make_pair(language_codes[i], native_display_name); |
+ } |
+ DCHECK_EQ(display_names.size(), language_map.size()); |
+ |
+ // Sort display names using locale specific sorter. |
+ l10n_util::SortStrings16(app_locale, &display_names); |
+ |
+ // Build the language list from the language map. |
+ ListValue* language_list = new ListValue(); |
+ for (size_t i = 0; i < display_names.size(); ++i) { |
+ const LanguagePair& pair = language_map[display_names[i]]; |
+ DictionaryValue* dictionary = new DictionaryValue(); |
+ dictionary->SetString("code", pair.first); |
+ dictionary->SetString("displayName", display_names[i]); |
+ dictionary->SetString("nativeDisplayName", pair.second); |
+ language_list->Append(dictionary); |
+ } |
+ |
+ return language_list; |
+} |
+#endif |
+ |
DictionaryValue* LanguageOptionsHandler::GetUiLanguageCodeSet() { |
DictionaryValue* dictionary = new DictionaryValue(); |
const std::vector<std::string>& available_locales = |
@@ -257,6 +342,7 @@ |
return dictionary; |
} |
+#if defined(OS_CHROMEOS) |
void LanguageOptionsHandler::InputMethodDisableCallback( |
const ListValue* args) { |
const std::string input_method_id = WideToASCII(ExtractStringValue(args)); |
@@ -280,6 +366,7 @@ |
"InputMethodOptions_Open_%s", input_method_id.c_str()); |
UserMetrics::RecordComputedAction(action); |
} |
+#endif |
void LanguageOptionsHandler::LanguageOptionsOpenCallback( |
const ListValue* args) { |
@@ -293,7 +380,12 @@ |
const std::string action = StringPrintf( |
"LanguageOptions_UiLanguageChange_%s", language_code.c_str()); |
UserMetrics::RecordComputedAction(action); |
+#if defined(OS_CHROMEOS) |
dom_ui_->GetProfile()->ChangeApplicationLocale(language_code, false); |
+#else |
+ PrefService* prefs = dom_ui_->GetProfile()->GetPrefs(); |
+ prefs->SetString(prefs::kApplicationLocale, language_code); |
+#endif |
dom_ui_->CallJavascriptFunction( |
L"options.LanguageOptions.uiLanguageSaved"); |
} |
@@ -307,16 +399,21 @@ |
UserMetrics::RecordComputedAction(action); |
} |
-void LanguageOptionsHandler::SignOutCallback(const ListValue* args) { |
+void LanguageOptionsHandler::RestartCallback(const ListValue* args) { |
+#if defined(OS_CHROMEOS) |
UserMetrics::RecordAction(UserMetricsAction("LanguageOptions_SignOut")); |
Browser* browser = Browser::GetBrowserForController( |
&dom_ui_->tab_contents()->controller(), NULL); |
if (browser) |
browser->ExecuteCommand(IDC_EXIT); |
+#else |
+ UserMetrics::RecordAction(UserMetricsAction("LanguageOptions_Restart")); |
+ |
+ // Set the flag to restore state after the restart. |
+ PrefService* pref_service = g_browser_process->local_state(); |
+ pref_service->SetBoolean(prefs::kRestartLastSessionOnShutdown, true); |
+ BrowserList::CloseAllBrowsersAndExit(); |
+#endif |
} |
-} // namespace chromeos |
- |
-#endif // OS_CHROMEOS |
- |