| Index: chrome/browser/chromeos/dom_ui/language_options_handler.cc
|
| diff --git a/chrome/browser/chromeos/dom_ui/language_options_handler.cc b/chrome/browser/chromeos/dom_ui/language_options_handler.cc
|
| index 366ee791fcbea365e03c29829423557cbd34da42..43a904177b801aaa44f0954dfd4d5cedb4c30119 100644
|
| --- a/chrome/browser/chromeos/dom_ui/language_options_handler.cc
|
| +++ b/chrome/browser/chromeos/dom_ui/language_options_handler.cc
|
| @@ -4,6 +4,10 @@
|
|
|
| #include "chrome/browser/chromeos/dom_ui/language_options_handler.h"
|
|
|
| +#include <map>
|
| +#include <string>
|
| +#include <utility>
|
| +
|
| #include "app/l10n_util.h"
|
| #include "base/utf_string_conversions.h"
|
| #include "base/values.h"
|
| @@ -90,17 +94,42 @@ ListValue* LanguageOptionsHandler::GetInputMethodList() {
|
| }
|
|
|
| ListValue* LanguageOptionsHandler::GetLanguageList() {
|
| - ListValue* language_list = new ListValue();
|
| -
|
| + // 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, std::wstring> LanguagePair;
|
| + typedef std::map<std::wstring, LanguagePair> LanguageMap;
|
| + LanguageMap language_map;
|
| + // The auxiliary list mentioned above.
|
| + std::vector<std::wstring> display_names;
|
| +
|
| + // Build the list of display names, and build the language map.
|
| const std::vector<std::string>& locales = l10n_util::GetAvailableLocales();
|
| for (size_t i = 0; i < locales.size(); ++i) {
|
| - DictionaryValue* dictionary = new DictionaryValue();
|
| - dictionary->SetString(L"code", UTF8ToWide(locales[i]));
|
| - dictionary->SetString(L"displayName",
|
| - chromeos::input_method::GetLanguageDisplayNameFromCode(locales[i]));
|
| - dictionary->SetString(L"nativeDisplayName",
|
| + const std::wstring display_name =
|
| + chromeos::input_method::GetLanguageDisplayNameFromCode(locales[i]);
|
| + const std::wstring native_display_name =
|
| chromeos::input_method::GetLanguageNativeDisplayNameFromCode(
|
| - locales[i]));
|
| + locales[i]);
|
| + display_names.push_back(display_name);
|
| + language_map[display_name] =
|
| + std::make_pair(locales[i], native_display_name);
|
| + }
|
| + DCHECK_EQ(display_names.size(), language_map.size());
|
| +
|
| + // Sort display names using locale specific sorter.
|
| + l10n_util::SortStrings(g_browser_process->GetApplicationLocale(),
|
| + &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(L"code", pair.first);
|
| + dictionary->SetString(L"displayName", display_names[i]);
|
| + dictionary->SetString(L"nativeDisplayName", pair.second);
|
| language_list->Append(dictionary);
|
| }
|
|
|
|
|