| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/ui/prefs/prefs_tab_helper.h" | 5 #include "chrome/browser/ui/prefs/prefs_tab_helper.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/prefs/overlay_user_pref_store.h" | 9 #include "base/prefs/overlay_user_pref_store.h" |
| 10 #include "base/prefs/pref_service.h" | 10 #include "base/prefs/pref_service.h" |
| (...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 131 const char* pref_name = pref_name_str.c_str(); | 131 const char* pref_name = pref_name_str.c_str(); |
| 132 if (fonts_with_defaults.find(pref_name) == fonts_with_defaults.end()) { | 132 if (fonts_with_defaults.find(pref_name) == fonts_with_defaults.end()) { |
| 133 // We haven't already set a default value for this font preference, so set | 133 // We haven't already set a default value for this font preference, so set |
| 134 // an empty string as the default. | 134 // an empty string as the default. |
| 135 registry->RegisterStringPref( | 135 registry->RegisterStringPref( |
| 136 pref_name, "", PrefRegistrySyncable::UNSYNCABLE_PREF); | 136 pref_name, "", PrefRegistrySyncable::UNSYNCABLE_PREF); |
| 137 } | 137 } |
| 138 } | 138 } |
| 139 } | 139 } |
| 140 | 140 |
| 141 #if !defined(OS_ANDROID) |
| 141 // Registers |obs| to observe per-script font prefs under the path |map_name|. | 142 // Registers |obs| to observe per-script font prefs under the path |map_name|. |
| 143 // On android, there's no exposed way to change these prefs, so we can save |
| 144 // ~715KB of heap and some startup cycles by avoiding observing these prefs |
| 145 // since they will never change. |
| 142 void RegisterFontFamilyMapObserver( | 146 void RegisterFontFamilyMapObserver( |
| 143 PrefChangeRegistrar* registrar, | 147 PrefChangeRegistrar* registrar, |
| 144 const char* map_name, | 148 const char* map_name, |
| 145 const PrefChangeRegistrar::NamedChangeCallback& obs) { | 149 const PrefChangeRegistrar::NamedChangeCallback& obs) { |
| 146 DCHECK(StartsWithASCII(map_name, "webkit.webprefs.", true)); | 150 DCHECK(StartsWithASCII(map_name, "webkit.webprefs.", true)); |
| 147 for (size_t i = 0; i < prefs::kWebKitScriptsForFontFamilyMapsLength; ++i) { | 151 for (size_t i = 0; i < prefs::kWebKitScriptsForFontFamilyMapsLength; ++i) { |
| 148 const char* script = prefs::kWebKitScriptsForFontFamilyMaps[i]; | 152 const char* script = prefs::kWebKitScriptsForFontFamilyMaps[i]; |
| 149 std::string pref_name = base::StringPrintf("%s.%s", map_name, script); | 153 std::string pref_name = base::StringPrintf("%s.%s", map_name, script); |
| 150 registrar->Add(pref_name.c_str(), obs); | 154 registrar->Add(pref_name.c_str(), obs); |
| 151 } | 155 } |
| 152 } | 156 } |
| 157 #endif // !defined(OS_ANDROID) |
| 153 | 158 |
| 154 struct FontDefault { | 159 struct FontDefault { |
| 155 const char* pref_name; | 160 const char* pref_name; |
| 156 int resource_id; | 161 int resource_id; |
| 157 }; | 162 }; |
| 158 | 163 |
| 159 // Font pref defaults. The prefs that have defaults vary by platform, since not | 164 // Font pref defaults. The prefs that have defaults vary by platform, since not |
| 160 // all platforms have fonts for all scripts for all generic families. | 165 // all platforms have fonts for all scripts for all generic families. |
| 161 // TODO(falken): add proper defaults when possible for all | 166 // TODO(falken): add proper defaults when possible for all |
| 162 // platforms/scripts/generic families. | 167 // platforms/scripts/generic families. |
| (...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 380 | 385 |
| 381 PrefChangeRegistrar::NamedChangeCallback webkit_callback = base::Bind( | 386 PrefChangeRegistrar::NamedChangeCallback webkit_callback = base::Bind( |
| 382 &PrefsTabHelper::OnWebPrefChanged, base::Unretained(this)); | 387 &PrefsTabHelper::OnWebPrefChanged, base::Unretained(this)); |
| 383 for (int i = 0; i < kPrefsToObserveLength; ++i) { | 388 for (int i = 0; i < kPrefsToObserveLength; ++i) { |
| 384 const char* pref_name = kPrefsToObserve[i]; | 389 const char* pref_name = kPrefsToObserve[i]; |
| 385 DCHECK(std::string(pref_name) == prefs::kDefaultCharset || | 390 DCHECK(std::string(pref_name) == prefs::kDefaultCharset || |
| 386 StartsWithASCII(pref_name, "webkit.webprefs.", true)); | 391 StartsWithASCII(pref_name, "webkit.webprefs.", true)); |
| 387 pref_change_registrar_.Add(pref_name, webkit_callback); | 392 pref_change_registrar_.Add(pref_name, webkit_callback); |
| 388 } | 393 } |
| 389 | 394 |
| 395 #if !defined(OS_ANDROID) |
| 390 RegisterFontFamilyMapObserver(&pref_change_registrar_, | 396 RegisterFontFamilyMapObserver(&pref_change_registrar_, |
| 391 prefs::kWebKitStandardFontFamilyMap, | 397 prefs::kWebKitStandardFontFamilyMap, |
| 392 webkit_callback); | 398 webkit_callback); |
| 393 RegisterFontFamilyMapObserver(&pref_change_registrar_, | 399 RegisterFontFamilyMapObserver(&pref_change_registrar_, |
| 394 prefs::kWebKitFixedFontFamilyMap, | 400 prefs::kWebKitFixedFontFamilyMap, |
| 395 webkit_callback); | 401 webkit_callback); |
| 396 RegisterFontFamilyMapObserver(&pref_change_registrar_, | 402 RegisterFontFamilyMapObserver(&pref_change_registrar_, |
| 397 prefs::kWebKitSerifFontFamilyMap, | 403 prefs::kWebKitSerifFontFamilyMap, |
| 398 webkit_callback); | 404 webkit_callback); |
| 399 RegisterFontFamilyMapObserver(&pref_change_registrar_, | 405 RegisterFontFamilyMapObserver(&pref_change_registrar_, |
| 400 prefs::kWebKitSansSerifFontFamilyMap, | 406 prefs::kWebKitSansSerifFontFamilyMap, |
| 401 webkit_callback); | 407 webkit_callback); |
| 402 RegisterFontFamilyMapObserver(&pref_change_registrar_, | 408 RegisterFontFamilyMapObserver(&pref_change_registrar_, |
| 403 prefs::kWebKitCursiveFontFamilyMap, | 409 prefs::kWebKitCursiveFontFamilyMap, |
| 404 webkit_callback); | 410 webkit_callback); |
| 405 RegisterFontFamilyMapObserver(&pref_change_registrar_, | 411 RegisterFontFamilyMapObserver(&pref_change_registrar_, |
| 406 prefs::kWebKitFantasyFontFamilyMap, | 412 prefs::kWebKitFantasyFontFamilyMap, |
| 407 webkit_callback); | 413 webkit_callback); |
| 408 RegisterFontFamilyMapObserver(&pref_change_registrar_, | 414 RegisterFontFamilyMapObserver(&pref_change_registrar_, |
| 409 prefs::kWebKitPictographFontFamilyMap, | 415 prefs::kWebKitPictographFontFamilyMap, |
| 410 webkit_callback); | 416 webkit_callback); |
| 417 #endif // !defined(OS_ANDROID) |
| 411 } | 418 } |
| 412 | 419 |
| 413 renderer_preferences_util::UpdateFromSystemSettings( | 420 renderer_preferences_util::UpdateFromSystemSettings( |
| 414 web_contents_->GetMutableRendererPrefs(), GetProfile()); | 421 web_contents_->GetMutableRendererPrefs(), GetProfile()); |
| 415 | 422 |
| 416 registrar_.Add(this, chrome::NOTIFICATION_USER_STYLE_SHEET_UPDATED, | 423 registrar_.Add(this, chrome::NOTIFICATION_USER_STYLE_SHEET_UPDATED, |
| 417 content::NotificationService::AllSources()); | 424 content::NotificationService::AllSources()); |
| 418 #if defined(OS_POSIX) && !defined(OS_MACOSX) && defined(ENABLE_THEMES) | 425 #if defined(OS_POSIX) && !defined(OS_MACOSX) && defined(ENABLE_THEMES) |
| 419 registrar_.Add(this, chrome::NOTIFICATION_BROWSER_THEME_CHANGED, | 426 registrar_.Add(this, chrome::NOTIFICATION_BROWSER_THEME_CHANGED, |
| 420 content::Source<ThemeService>( | 427 content::Source<ThemeService>( |
| (...skipping 233 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 654 WebPreferences web_prefs = | 661 WebPreferences web_prefs = |
| 655 web_contents_->GetRenderViewHost()->GetWebkitPreferences(); | 662 web_contents_->GetRenderViewHost()->GetWebkitPreferences(); |
| 656 OverrideFontFamily(&web_prefs, generic_family, script, ""); | 663 OverrideFontFamily(&web_prefs, generic_family, script, ""); |
| 657 web_contents_->GetRenderViewHost()->UpdateWebkitPreferences(web_prefs); | 664 web_contents_->GetRenderViewHost()->UpdateWebkitPreferences(web_prefs); |
| 658 return; | 665 return; |
| 659 } | 666 } |
| 660 } | 667 } |
| 661 | 668 |
| 662 UpdateWebPreferences(); | 669 UpdateWebPreferences(); |
| 663 } | 670 } |
| OLD | NEW |