diff options
author | joi@chromium.org <joi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-03-02 17:02:25 +0000 |
---|---|---|
committer | joi@chromium.org <joi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-03-02 17:02:25 +0000 |
commit | 5879cef53e60384391c36e6d7e4062e8b763c976 (patch) | |
tree | 4718389bd1adff25f6741d630f2f87bf003e6574 /chrome/browser/ui/browser_instant_controller.cc | |
parent | 6f75eb5610fe3144a16942c4fd5da8eb59ec2146 (diff) | |
download | chromium_src-5879cef53e60384391c36e6d7e4062e8b763c976.zip chromium_src-5879cef53e60384391c36e6d7e4062e8b763c976.tar.gz chromium_src-5879cef53e60384391c36e6d7e4062e8b763c976.tar.bz2 |
Fix prefs registration in BrowserInstantController.
Registration should happen prior to PrefService construction, so accepting a PrefService parameter to RegisterUserPrefs is a no-no.
To keep the existing semantics, this change adds a PrefService::SetDefaultPrefValue method that allows you to change the default value for a pref.
As BrowserInstantController was the last method called from chrome::RegisterUserPrefs that required a PrefService pointer, this also removes the PrefService parameter from the latter function and updates callers.
TBR=ben@chromium.org
BUG=155525
Review URL: https://chromiumcodereview.appspot.com/12315116
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@185712 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/ui/browser_instant_controller.cc')
-rw-r--r-- | chrome/browser/ui/browser_instant_controller.cc | 54 |
1 files changed, 37 insertions, 17 deletions
diff --git a/chrome/browser/ui/browser_instant_controller.cc b/chrome/browser/ui/browser_instant_controller.cc index 2d17390..0b69d66 100644 --- a/chrome/browser/ui/browser_instant_controller.cc +++ b/chrome/browser/ui/browser_instant_controller.cc @@ -52,7 +52,40 @@ BrowserInstantController::BrowserInstantController(Browser* browser) chrome::search::IsInstantExtendedAPIEnabled(profile())), instant_unload_handler_(browser), initialized_theme_info_(false) { - profile_pref_registrar_.Init(profile()->GetPrefs()); + PrefService* prefs = profile()->GetPrefs(); + + // The kInstantExtendedEnabled and kInstantEnabled preferences are + // separate, as the way opt-in is done is a bit different, and + // because the experiment that controls the behavior of + // kInstantExtendedEnabled (value retrieved via + // search::GetInstantExtendedDefaultSetting) may take different + // settings on different Chrome set-ups for the same user. + // + // In one mode of the experiment, however, the + // kInstantExtendedEnabled preference's default value is set to the + // existing value of kInstantEnabled. + // + // Because this requires reading the value of the kInstantEnabled + // value, we reset the default for kInstantExtendedEnabled here, + // instead of fully determining the default in RegisterUserPrefs, + // below. + bool instant_extended_default = true; + switch (search::GetInstantExtendedDefaultSetting()) { + case search::INSTANT_DEFAULT_ON: + instant_extended_default = true; + break; + case search::INSTANT_USE_EXISTING: + instant_extended_default = prefs->GetBoolean(prefs::kInstantEnabled); + case search::INSTANT_DEFAULT_OFF: + instant_extended_default = false; + break; + } + + prefs->SetDefaultPrefValue( + prefs::kInstantExtendedEnabled, + Value::CreateBooleanValue(instant_extended_default)); + + profile_pref_registrar_.Init(prefs); profile_pref_registrar_.Add( GetInstantPrefName(profile()), base::Bind(&BrowserInstantController::ResetInstant, @@ -82,29 +115,16 @@ bool BrowserInstantController::IsInstantEnabled(Profile* profile) { } void BrowserInstantController::RegisterUserPrefs( - PrefService* prefs, PrefRegistrySyncable* registry) { - // TODO(joi): Get rid of the need for PrefService param above. registry->RegisterBooleanPref(prefs::kInstantConfirmDialogShown, false, PrefRegistrySyncable::SYNCABLE_PREF); registry->RegisterBooleanPref(prefs::kInstantEnabled, false, PrefRegistrySyncable::SYNCABLE_PREF); - bool instant_extended_default = true; - switch (search::GetInstantExtendedDefaultSetting()) { - case search::INSTANT_DEFAULT_ON: - instant_extended_default = true; - break; - case search::INSTANT_USE_EXISTING: - instant_extended_default = prefs->GetBoolean(prefs::kInstantEnabled); - break; - case search::INSTANT_DEFAULT_OFF: - instant_extended_default = false; - break; - } - + // Note that the default for this pref gets reset in the + // BrowserInstantController constructor. registry->RegisterBooleanPref(prefs::kInstantExtendedEnabled, - instant_extended_default, + false, PrefRegistrySyncable::SYNCABLE_PREF); } |