Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/locale_change_guard.h" | 5 #include "chrome/browser/chromeos/locale_change_guard.h" |
| 6 | 6 |
| 7 #include "app/l10n_util.h" | 7 #include "app/l10n_util.h" |
| 8 #include "base/utf_string_conversions.h" | 8 #include "base/utf_string_conversions.h" |
| 9 #include "chrome/app/chrome_command_ids.h" | 9 #include "chrome/app/chrome_command_ids.h" |
| 10 #include "chrome/browser/browser_process.h" | 10 #include "chrome/browser/browser_process.h" |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 26 namespace chromeos { | 26 namespace chromeos { |
| 27 | 27 |
| 28 LocaleChangeGuard::LocaleChangeGuard() | 28 LocaleChangeGuard::LocaleChangeGuard() |
| 29 : profile_id_(Profile::InvalidProfileId), | 29 : profile_id_(Profile::InvalidProfileId), |
| 30 tab_contents_(NULL), | 30 tab_contents_(NULL), |
| 31 note_(NULL), | 31 note_(NULL), |
| 32 reverted_(false) { | 32 reverted_(false) { |
| 33 } | 33 } |
| 34 | 34 |
| 35 void LocaleChangeGuard::RevertLocaleChange(const ListValue* list) { | 35 void LocaleChangeGuard::RevertLocaleChange(const ListValue* list) { |
| 36 if (note_ == NULL | |
| 37 || tab_contents_ == NULL | |
|
brettw
2011/01/17 16:40:30
In Chrome we'll normally put the || at the end of
Denis Lagno
2011/01/17 17:44:13
Done.
| |
| 38 || from_locale_.empty() | |
| 39 || to_locale_.empty()) { | |
| 40 NOTREACHED(); | |
| 41 return; | |
| 42 } | |
| 43 if (reverted_) | |
| 44 return; | |
| 45 | |
| 46 PrefService* prefs = tab_contents_->profile()->GetPrefs(); | |
| 47 if (prefs == NULL) | |
| 48 return; | |
| 49 | |
| 36 reverted_ = true; | 50 reverted_ = true; |
| 37 UserMetrics::RecordAction(UserMetricsAction("LanguageChange_Revert")); | 51 UserMetrics::RecordAction(UserMetricsAction("LanguageChange_Revert")); |
| 38 tab_contents_->profile()->ChangeApplicationLocale(from_locale_, true); | 52 tab_contents_->profile()->ChangeApplicationLocale(from_locale_, true); |
| 39 PrefService* prefs = tab_contents_->profile()->GetPrefs(); | 53 prefs->SetString(prefs::kApplicationLocaleBackup, from_locale_); |
| 40 if (prefs) { | 54 prefs->ClearPref(prefs::kApplicationLocaleAccepted); |
| 41 prefs->SetString(prefs::kApplicationLocaleBackup, from_locale_); | 55 prefs->ScheduleSavePersistentPrefs(); |
| 42 prefs->ClearPref(prefs::kApplicationLocaleAccepted); | 56 |
| 43 prefs->ScheduleSavePersistentPrefs(); | |
| 44 } | |
| 45 Browser* browser = Browser::GetBrowserForController( | 57 Browser* browser = Browser::GetBrowserForController( |
| 46 &tab_contents_->controller(), NULL); | 58 &tab_contents_->controller(), NULL); |
| 47 if (browser) | 59 if (browser) |
| 48 browser->ExecuteCommand(IDC_EXIT); | 60 browser->ExecuteCommand(IDC_EXIT); |
| 49 } | 61 } |
| 50 | 62 |
| 51 void LocaleChangeGuard::CheckLocaleChange(TabContents* tab_contents) { | 63 void LocaleChangeGuard::CheckLocaleChange(TabContents* tab_contents) { |
| 52 // We want notification to be shown no more than once per session. | 64 // We want notification to be shown no more than once per session. |
| 53 if (note_ != NULL) | 65 if (note_ != NULL) |
| 54 return; | 66 return; |
| 67 DCHECK(note_ == NULL && tab_contents_ == NULL); | |
| 68 DCHECK(from_locale_.empty() && to_locale_.empty()); | |
| 69 | |
| 55 // We check profile Id because: | 70 // We check profile Id because: |
| 56 // (1) we want to exit fast in common case when nothing should be done. | 71 // (1) we want to exit fast in common case when nothing should be done. |
| 57 // (2) on ChromeOS this guard may be invoked for a dummy profile first time. | 72 // (2) on ChromeOS this guard may be invoked for a dummy profile first time. |
| 58 ProfileId cur_profile_id = tab_contents->profile()->GetRuntimeId(); | 73 ProfileId cur_profile_id = tab_contents->profile()->GetRuntimeId(); |
| 59 if (cur_profile_id == profile_id_) | 74 if (cur_profile_id == profile_id_) { |
| 75 // We have already checked this profile, exiting fast. | |
| 60 return; | 76 return; |
| 77 } | |
| 61 profile_id_ = cur_profile_id; | 78 profile_id_ = cur_profile_id; |
| 79 | |
| 62 std::string cur_locale = g_browser_process->GetApplicationLocale(); | 80 std::string cur_locale = g_browser_process->GetApplicationLocale(); |
| 63 if (cur_locale.empty()) | 81 if (cur_locale.empty()) { |
| 82 NOTREACHED(); | |
| 64 return; | 83 return; |
| 84 } | |
| 85 | |
| 65 PrefService* prefs = tab_contents->profile()->GetPrefs(); | 86 PrefService* prefs = tab_contents->profile()->GetPrefs(); |
| 66 if (prefs == NULL) | 87 if (prefs == NULL) |
| 67 return; | 88 return; |
| 68 to_locale_ = prefs->GetString(prefs::kApplicationLocaleOverride); | 89 |
| 69 if (!to_locale_.empty()) { | 90 std::string to_locale = prefs->GetString(prefs::kApplicationLocaleOverride); |
| 70 DCHECK(to_locale_ == cur_locale); | 91 if (!to_locale.empty()) { |
| 92 DCHECK(to_locale == cur_locale); | |
| 71 return; | 93 return; |
| 72 } | 94 } |
| 73 to_locale_ = prefs->GetString(prefs::kApplicationLocale); | 95 |
| 74 if (to_locale_ != cur_locale) | 96 to_locale = prefs->GetString(prefs::kApplicationLocale); |
| 97 if (to_locale != cur_locale) { | |
| 98 // This conditional branch can occur in case kApplicationLocale | |
| 99 // preference was modified by synchronization. | |
| 75 return; | 100 return; |
| 76 from_locale_ = prefs->GetString(prefs::kApplicationLocaleBackup); | 101 } |
| 77 if (from_locale_.empty() || from_locale_ == to_locale_) | 102 |
| 78 return; | 103 DCHECK(note_ == NULL && tab_contents_ == NULL); |
|
brettw
2011/01/17 16:40:30
You already did these two DCHECKs at the top of th
Denis Lagno
2011/01/17 17:44:13
Done.
| |
| 79 note_.reset(new chromeos::SystemNotification( | 104 DCHECK(from_locale_.empty() && to_locale_.empty()); |
| 80 tab_contents->profile(), | 105 std::string from_locale = prefs->GetString(prefs::kApplicationLocaleBackup); |
| 81 new Delegate(this), | 106 if (!from_locale.empty() && from_locale != to_locale) { |
|
brettw
2011/01/17 16:40:30
I actually liked the old way of returning early in
Denis Lagno
2011/01/17 17:44:13
Done.
| |
| 82 IDR_DEFAULT_FAVICON, | 107 // Locale change detected, showing notification. |
| 83 l10n_util::GetStringUTF16( | 108 from_locale_ = from_locale; |
| 84 IDS_OPTIONS_SETTINGS_SECTION_TITLE_LANGUAGE))); | 109 to_locale_ = to_locale; |
| 85 tab_contents_ = tab_contents; | 110 tab_contents_ = tab_contents; |
| 86 note_->Show( | 111 note_.reset(new chromeos::SystemNotification( |
| 87 l10n_util::GetStringFUTF16( | 112 tab_contents->profile(), |
| 88 IDS_LOCALE_CHANGE_MESSAGE, | 113 new Delegate(this), |
| 89 l10n_util::GetDisplayNameForLocale(from_locale_, to_locale_, true), | 114 IDR_DEFAULT_FAVICON, |
| 90 l10n_util::GetDisplayNameForLocale(to_locale_, to_locale_, true)), | 115 l10n_util::GetStringUTF16( |
| 91 l10n_util::GetStringUTF16(IDS_LOCALE_CHANGE_REVERT_MESSAGE), | 116 IDS_OPTIONS_SETTINGS_SECTION_TITLE_LANGUAGE))); |
| 92 NewCallback(this, &LocaleChangeGuard::RevertLocaleChange), | 117 note_->Show( |
| 93 true, // urgent | 118 l10n_util::GetStringFUTF16( |
| 94 false); // non-sticky | 119 IDS_LOCALE_CHANGE_MESSAGE, |
| 120 l10n_util::GetDisplayNameForLocale(from_locale_, to_locale_, true), | |
| 121 l10n_util::GetDisplayNameForLocale(to_locale_, to_locale_, true)), | |
| 122 l10n_util::GetStringUTF16(IDS_LOCALE_CHANGE_REVERT_MESSAGE), | |
| 123 NewCallback(this, &LocaleChangeGuard::RevertLocaleChange), | |
| 124 true, // urgent | |
| 125 false); // non-sticky | |
| 126 } | |
| 95 } | 127 } |
| 96 | 128 |
| 97 void LocaleChangeGuard::AcceptLocaleChange() { | 129 void LocaleChangeGuard::AcceptLocaleChange() { |
| 130 if (note_ == NULL | |
| 131 || tab_contents_ == NULL | |
|
brettw
2011/01/17 16:40:30
Ditto with || at the end.
Denis Lagno
2011/01/17 17:44:13
Done.
| |
| 132 || from_locale_.empty() | |
| 133 || to_locale_.empty()) { | |
| 134 NOTREACHED(); | |
| 135 return; | |
| 136 } | |
| 137 | |
| 98 // Check whether locale has been reverted or changed. | 138 // Check whether locale has been reverted or changed. |
| 99 // If not: mark current locale as accepted. | 139 // If not: mark current locale as accepted. |
| 100 if (tab_contents_ == NULL) | |
| 101 return; | |
| 102 if (reverted_) | 140 if (reverted_) |
| 103 return; | 141 return; |
| 104 PrefService* prefs = tab_contents_->profile()->GetPrefs(); | 142 PrefService* prefs = tab_contents_->profile()->GetPrefs(); |
| 105 if (prefs == NULL) | 143 if (prefs == NULL) |
| 106 return; | 144 return; |
| 107 std::string override_locale = | 145 std::string override_locale = |
| 108 prefs->GetString(prefs::kApplicationLocaleOverride); | 146 prefs->GetString(prefs::kApplicationLocaleOverride); |
| 109 if (!override_locale.empty()) | 147 if (!override_locale.empty()) |
| 110 return; | 148 return; |
| 111 if (prefs->GetString(prefs::kApplicationLocale) != to_locale_) | 149 if (prefs->GetString(prefs::kApplicationLocale) != to_locale_) |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 125 if (by_user) | 163 if (by_user) |
| 126 master_->AcceptLocaleChange(); | 164 master_->AcceptLocaleChange(); |
| 127 } | 165 } |
| 128 | 166 |
| 129 std::string LocaleChangeGuard::Delegate::id() const { | 167 std::string LocaleChangeGuard::Delegate::id() const { |
| 130 // Arbitrary unique Id. | 168 // Arbitrary unique Id. |
| 131 return "8c386938-1e3f-11e0-ac7b-18a90520e2e5"; | 169 return "8c386938-1e3f-11e0-ac7b-18a90520e2e5"; |
| 132 } | 170 } |
| 133 | 171 |
| 134 } // namespace chromeos | 172 } // namespace chromeos |
| OLD | NEW |