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

Unified Diff: chrome/browser/ui/prefs/prefs_tab_helper.cc

Issue 11345008: Remove content::NotificationObserver dependency from most Prefs code. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Merge to head for commit Created 8 years, 1 month 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/prefs/prefs_tab_helper.cc
diff --git a/chrome/browser/ui/prefs/prefs_tab_helper.cc b/chrome/browser/ui/prefs/prefs_tab_helper.cc
index 8074e6d0ba91edc723438f6fbc66b3c636d77b70..1d3e3d4f62fd5b9f3d1bed83d1412c061f3d84d8 100644
--- a/chrome/browser/ui/prefs/prefs_tab_helper.cc
+++ b/chrome/browser/ui/prefs/prefs_tab_helper.cc
@@ -137,7 +137,7 @@ void RegisterFontFamilyMap(PrefService* prefs, const char* map_name) {
// Registers |obs| to observe per-script font prefs under the path |map_name|.
void RegisterFontFamilyMapObserver(PrefChangeRegistrar* registrar,
const char* map_name,
- content::NotificationObserver* obs) {
+ PrefObserver* obs) {
for (size_t i = 0; i < prefs::kWebKitScriptsForFontFamilyMapsLength; ++i) {
const char* script = prefs::kWebKitScriptsForFontFamilyMaps[i];
std::string pref_name = base::StringPrintf("%s.%s", map_name, script);
@@ -566,27 +566,26 @@ void PrefsTabHelper::Observe(int type,
break;
}
#endif
- case chrome::NOTIFICATION_PREF_CHANGED: {
- std::string* pref_name_in = content::Details<std::string>(details).ptr();
- DCHECK(content::Source<PrefService>(source).ptr() ==
- GetProfile()->GetPrefs());
- if (*pref_name_in == prefs::kDefaultCharset ||
- StartsWithASCII(*pref_name_in, "webkit.webprefs.", true)) {
- OnWebPrefChanged(*pref_name_in);
- } else if (*pref_name_in == prefs::kDefaultZoomLevel ||
- *pref_name_in == prefs::kEnableReferrers ||
- *pref_name_in == prefs::kEnableDoNotTrack) {
- UpdateRendererPreferences();
- } else {
- NOTREACHED() << "unexpected pref change notification" << *pref_name_in;
- }
- break;
- }
default:
NOTREACHED();
}
}
+void PrefsTabHelper::OnPreferenceChanged(PrefServiceBase* service,
+ const std::string& pref_name_in) {
+ DCHECK_EQ(GetProfile()->GetPrefs(), service);
+ if (pref_name_in == prefs::kDefaultCharset ||
+ StartsWithASCII(pref_name_in, "webkit.webprefs.", true)) {
+ OnWebPrefChanged(pref_name_in);
+ } else if (pref_name_in == prefs::kDefaultZoomLevel ||
+ pref_name_in == prefs::kEnableReferrers ||
+ pref_name_in == prefs::kEnableDoNotTrack) {
+ UpdateRendererPreferences();
+ } else {
+ NOTREACHED() << "unexpected pref change notification" << pref_name_in;
+ }
+}
+
void PrefsTabHelper::UpdateWebPreferences() {
web_contents_->GetRenderViewHost()->UpdateWebkitPreferences(
web_contents_->GetRenderViewHost()->GetWebkitPreferences());
« no previous file with comments | « chrome/browser/ui/prefs/prefs_tab_helper.h ('k') | chrome/browser/ui/views/location_bar/location_bar_view.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698