Index: chrome/browser/prefs/chrome_pref_service_factory.cc |
diff --git a/chrome/browser/prefs/chrome_pref_service_builder.cc b/chrome/browser/prefs/chrome_pref_service_factory.cc |
similarity index 67% |
rename from chrome/browser/prefs/chrome_pref_service_builder.cc |
rename to chrome/browser/prefs/chrome_pref_service_factory.cc |
index 77fb3dee4636b6ac84ff4dec2792b3f0dc6e23e3..cc8a6904c6aad370d5c5c81b9af412bf13094fd8 100644 |
--- a/chrome/browser/prefs/chrome_pref_service_builder.cc |
+++ b/chrome/browser/prefs/chrome_pref_service_factory.cc |
@@ -2,7 +2,7 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "chrome/browser/prefs/chrome_pref_service_builder.h" |
+#include "chrome/browser/prefs/chrome_pref_service_factory.h" |
#include "base/bind.h" |
#include "base/file_path.h" |
@@ -57,14 +57,50 @@ PrefServiceBase* PrefServiceBase::FromBrowserContext(BrowserContext* context) { |
return static_cast<Profile*>(context)->GetPrefs(); |
} |
-ChromePrefServiceBuilder::ChromePrefServiceBuilder() { |
+ChromePrefServiceFactory::ChromePrefServiceFactory() { |
ResetDefaultState(); |
} |
-ChromePrefServiceBuilder::~ChromePrefServiceBuilder() { |
+ChromePrefServiceFactory::~ChromePrefServiceFactory() { |
} |
-PrefService* ChromePrefServiceBuilder::CreateChromePrefs( |
+PrefServiceSimple* ChromePrefServiceFactory::CreateLocalState( |
+ const FilePath& pref_filename, |
+ base::SequencedTaskRunner* pref_io_task_runner, |
+ policy::PolicyService* policy_service, |
+ PrefStore* extension_prefs, |
+ bool async) { |
+ PrepareBuilder(pref_filename, |
+ pref_io_task_runner, |
+ policy_service, |
+ extension_prefs, |
+ async); |
+ |
+ PrefServiceSimple* pref_service = new PrefServiceSimple(); |
+ builder_.Build(pref_service); |
+ ResetDefaultState(); |
+ return pref_service; |
+} |
+ |
+PrefServiceSyncable* ChromePrefServiceFactory::CreateProfilePrefs( |
+ const FilePath& pref_filename, |
+ base::SequencedTaskRunner* pref_io_task_runner, |
+ policy::PolicyService* policy_service, |
+ PrefStore* extension_prefs, |
+ bool async) { |
+ PrepareBuilder(pref_filename, |
+ pref_io_task_runner, |
+ policy_service, |
+ extension_prefs, |
+ async); |
+ |
+ PrefServiceSyncable* pref_service = new PrefServiceSyncable(); |
+ builder_.Build(pref_service); |
+ ResetDefaultState(); |
+ return pref_service; |
+} |
+ |
+void ChromePrefServiceFactory::PrepareBuilder( |
const FilePath& pref_filename, |
base::SequencedTaskRunner* pref_io_task_runner, |
policy::PolicyService* policy_service, |
@@ -85,26 +121,21 @@ PrefService* ChromePrefServiceBuilder::CreateChromePrefs( |
#if defined(ENABLE_CONFIGURATION_POLICY) |
using policy::ConfigurationPolicyPrefStore; |
- WithManagedPrefs( |
+ builder_.WithManagedPrefs( |
ConfigurationPolicyPrefStore::CreateMandatoryPolicyPrefStore( |
policy_service)); |
- WithRecommendedPrefs( |
+ builder_.WithRecommendedPrefs( |
ConfigurationPolicyPrefStore::CreateRecommendedPolicyPrefStore( |
policy_service)); |
#endif // ENABLE_CONFIGURATION_POLICY |
- WithAsync(async); |
- WithExtensionPrefs(extension_prefs); |
- WithCommandLinePrefs( |
+ builder_.WithAsync(async); |
+ builder_.WithExtensionPrefs(extension_prefs); |
+ builder_.WithCommandLinePrefs( |
new CommandLinePrefStore(CommandLine::ForCurrentProcess())); |
- WithUserPrefs(new JsonPrefStore(pref_filename, pref_io_task_runner)); |
- |
- PrefService* pref_service = Create(); |
- ResetDefaultState(); |
- return pref_service; |
+ builder_.WithUserPrefs(new JsonPrefStore(pref_filename, pref_io_task_runner)); |
} |
-void ChromePrefServiceBuilder::ResetDefaultState() { |
- WithReadErrorCallback(base::Bind(&HandleReadError)); |
- WithSyncAssociator(new PrefModelAssociator()); |
+void ChromePrefServiceFactory::ResetDefaultState() { |
+ builder_.WithReadErrorCallback(base::Bind(&HandleReadError)); |
} |