Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(437)

Side by Side Diff: chrome/browser/chromeos/base/locale_util.cc

Issue 620563002: ChromeOS NetworkScreenHandler should not call CheckAndResolveLocale on UI thread. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Cleanup. Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/chromeos/base/locale_util.h" 5 #include "chrome/browser/chromeos/base/locale_util.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "chrome/browser/browser_process.h" 9 #include "chrome/browser/browser_process.h"
10 #include "chrome/browser/chromeos/input_method/input_method_util.h" 10 #include "chrome/browser/chromeos/input_method/input_method_util.h"
11 #include "chromeos/ime/input_method_manager.h" 11 #include "chromeos/ime/input_method_manager.h"
12 #include "content/public/browser/browser_thread.h" 12 #include "content/public/browser/browser_thread.h"
13 #include "ui/base/resource/resource_bundle.h" 13 #include "ui/base/resource/resource_bundle.h"
14 #include "ui/gfx/platform_font_pango.h" 14 #include "ui/gfx/platform_font_pango.h"
15 15
16 namespace chromeos { 16 namespace chromeos {
17 17
18 namespace { 18 namespace {
19 19
20 struct SwitchLanguageData { 20 struct SwitchLanguageData {
21 SwitchLanguageData(const std::string& locale, 21 SwitchLanguageData(const std::string& locale,
22 const bool enable_locale_keyboard_layouts, 22 const bool enable_locale_keyboard_layouts,
23 const bool login_layouts_only, 23 const bool login_layouts_only,
24 scoped_ptr<locale_util::SwitchLanguageCallback> callback) 24 scoped_ptr<locale_util::SwitchLanguageCallback> callback)
25 : callback(callback.Pass()), 25 : callback(callback.Pass()),
26 locale(locale), 26 result(new locale_util::LanguageSwitchResult(locale,
27 std::string(),
28 false)),
27 enable_locale_keyboard_layouts(enable_locale_keyboard_layouts), 29 enable_locale_keyboard_layouts(enable_locale_keyboard_layouts),
28 login_layouts_only(login_layouts_only), 30 login_layouts_only(login_layouts_only) {}
29 success(false) {}
30 31
31 scoped_ptr<locale_util::SwitchLanguageCallback> callback; 32 scoped_ptr<locale_util::SwitchLanguageCallback> callback;
32 33
33 const std::string locale; 34 scoped_ptr<locale_util::LanguageSwitchResult> result;
34 const bool enable_locale_keyboard_layouts; 35 const bool enable_locale_keyboard_layouts;
35 const bool login_layouts_only; 36 const bool login_layouts_only;
36 std::string loaded_locale;
37 bool success;
38 }; 37 };
39 38
40 // Runs on SequencedWorkerPool thread under PostTaskAndReply(). 39 // Runs on SequencedWorkerPool thread under PostTaskAndReply().
41 // So data is owned by "Reply" part of PostTaskAndReply() process. 40 // So data is owned by "Reply" part of PostTaskAndReply() process.
42 void SwitchLanguageDoReloadLocale(SwitchLanguageData* data) { 41 void SwitchLanguageDoReloadLocale(SwitchLanguageData* data) {
43 DCHECK(!content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); 42 DCHECK(!content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
44 43
45 data->loaded_locale = 44 data->result->loaded_locale =
46 ResourceBundle::GetSharedInstance().ReloadLocaleResources(data->locale); 45 ResourceBundle::GetSharedInstance().ReloadLocaleResources(
46 data->result->requested_locale);
47 47
48 data->success = !data->loaded_locale.empty(); 48 data->result->success = !data->result->loaded_locale.empty();
49 49
50 ResourceBundle::GetSharedInstance().ReloadFonts(); 50 ResourceBundle::GetSharedInstance().ReloadFonts();
51 } 51 }
52 52
53 // Callback after SwitchLanguageDoReloadLocale() back in UI thread. 53 // Callback after SwitchLanguageDoReloadLocale() back in UI thread.
54 void FinishSwitchLanguage(scoped_ptr<SwitchLanguageData> data) { 54 void FinishSwitchLanguage(scoped_ptr<SwitchLanguageData> data) {
55 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); 55 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
56 if (data->success) { 56 if (data->result->success) {
57 g_browser_process->SetApplicationLocale(data->loaded_locale); 57 g_browser_process->SetApplicationLocale(data->result->loaded_locale);
58 58
59 if (data->enable_locale_keyboard_layouts) { 59 if (data->enable_locale_keyboard_layouts) {
60 input_method::InputMethodManager* manager = 60 input_method::InputMethodManager* manager =
61 input_method::InputMethodManager::Get(); 61 input_method::InputMethodManager::Get();
62 scoped_refptr<input_method::InputMethodManager::State> ime_state = 62 scoped_refptr<input_method::InputMethodManager::State> ime_state =
63 manager->GetActiveIMEState(); 63 manager->GetActiveIMEState();
64 if (data->login_layouts_only) { 64 if (data->login_layouts_only) {
65 // Enable the hardware keyboard layouts and locale-specific layouts 65 // Enable the hardware keyboard layouts and locale-specific layouts
66 // suitable for use on the login screen. This will also switch to the 66 // suitable for use on the login screen. This will also switch to the
67 // first hardware keyboard layout since the input method currently in 67 // first hardware keyboard layout since the input method currently in
68 // use may not be supported by the new locale. 68 // use may not be supported by the new locale.
69 ime_state->EnableLoginLayouts( 69 ime_state->EnableLoginLayouts(
70 data->loaded_locale, 70 data->result->loaded_locale,
71 manager->GetInputMethodUtil()->GetHardwareLoginInputMethodIds()); 71 manager->GetInputMethodUtil()->GetHardwareLoginInputMethodIds());
72 } else { 72 } else {
73 // Enable all hardware keyboard layouts. This will also switch to the 73 // Enable all hardware keyboard layouts. This will also switch to the
74 // first hardware keyboard layout. 74 // first hardware keyboard layout.
75 ime_state->ReplaceEnabledInputMethods( 75 ime_state->ReplaceEnabledInputMethods(
76 manager->GetInputMethodUtil()->GetHardwareInputMethodIds()); 76 manager->GetInputMethodUtil()->GetHardwareInputMethodIds());
77 77
78 // Enable all locale-specific layouts. 78 // Enable all locale-specific layouts.
79 std::vector<std::string> input_methods; 79 std::vector<std::string> input_methods;
80 manager->GetInputMethodUtil()->GetInputMethodIdsFromLanguageCode( 80 manager->GetInputMethodUtil()->GetInputMethodIdsFromLanguageCode(
81 data->loaded_locale, 81 data->result->loaded_locale,
82 input_method::kKeyboardLayoutsOnly, 82 input_method::kKeyboardLayoutsOnly,
83 &input_methods); 83 &input_methods);
84 for (std::vector<std::string>::const_iterator it = 84 for (std::vector<std::string>::const_iterator it =
85 input_methods.begin(); it != input_methods.end(); ++it) { 85 input_methods.begin(); it != input_methods.end(); ++it) {
86 ime_state->EnableInputMethod(*it); 86 ime_state->EnableInputMethod(*it);
87 } 87 }
88 } 88 }
89 } 89 }
90 } 90 }
91 gfx::PlatformFontPango::ReloadDefaultFont(); 91 gfx::PlatformFontPango::ReloadDefaultFont();
92 if (data->callback) 92 if (data->callback)
93 data->callback->Run(data->locale, data->loaded_locale, data->success); 93 data->callback->Run(data->result.Pass());
94 } 94 }
95 95
96 } // namespace 96 } // namespace
97 97
98 namespace locale_util { 98 namespace locale_util {
99 99
100 LanguageSwitchResult::LanguageSwitchResult(const std::string& requested_locale,
101 const std::string& loaded_locale,
102 bool success)
103 : requested_locale(requested_locale),
104 loaded_locale(loaded_locale),
105 success(success) {
106 }
107
100 void SwitchLanguage(const std::string& locale, 108 void SwitchLanguage(const std::string& locale,
101 const bool enable_locale_keyboard_layouts, 109 const bool enable_locale_keyboard_layouts,
102 const bool login_layouts_only, 110 const bool login_layouts_only,
103 scoped_ptr<SwitchLanguageCallback> callback) { 111 scoped_ptr<SwitchLanguageCallback> callback) {
104 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); 112 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
105 scoped_ptr<SwitchLanguageData> data( 113 scoped_ptr<SwitchLanguageData> data(
106 new SwitchLanguageData(locale, 114 new SwitchLanguageData(locale,
107 enable_locale_keyboard_layouts, 115 enable_locale_keyboard_layouts,
108 login_layouts_only, 116 login_layouts_only,
109 callback.Pass())); 117 callback.Pass()));
110 base::Closure reloader( 118 base::Closure reloader(
111 base::Bind(&SwitchLanguageDoReloadLocale, base::Unretained(data.get()))); 119 base::Bind(&SwitchLanguageDoReloadLocale, base::Unretained(data.get())));
112 content::BrowserThread::PostBlockingPoolTaskAndReply( 120 content::BrowserThread::PostBlockingPoolTaskAndReply(
113 FROM_HERE, 121 FROM_HERE,
114 reloader, 122 reloader,
115 base::Bind(&FinishSwitchLanguage, base::Passed(data.Pass()))); 123 base::Bind(&FinishSwitchLanguage, base::Passed(data.Pass())));
116 } 124 }
117 125
118 } // namespace locale_util 126 } // namespace locale_util
119 } // namespace chromeos 127 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698