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

Side by Side Diff: chrome/browser/prefs/pref_service_syncable_factory.cc

Issue 1326353002: Remove dependency of PrefSyncableService on Profile. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@pref_model_associator
Patch Set: Move files back to //chrome/browser/prefs & //chrome/test/base Created 5 years, 3 months 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/prefs/pref_service_syncable_factory.h" 5 #include "chrome/browser/prefs/pref_service_syncable_factory.h"
6 6
7 #include "base/prefs/default_pref_store.h" 7 #include "base/prefs/default_pref_store.h"
8 #include "base/prefs/pref_notifier_impl.h" 8 #include "base/prefs/pref_notifier_impl.h"
9 #include "base/prefs/pref_value_store.h" 9 #include "base/prefs/pref_value_store.h"
10 #include "base/trace_event/trace_event.h" 10 #include "base/trace_event/trace_event.h"
11 #include "chrome/browser/browser_process.h"
12 #include "chrome/browser/prefs/command_line_pref_store.h"
13 #include "chrome/browser/prefs/pref_service_syncable.h" 11 #include "chrome/browser/prefs/pref_service_syncable.h"
14 #include "components/pref_registry/pref_registry_syncable.h" 12 #include "components/pref_registry/pref_registry_syncable.h"
15 13
16 #if defined(ENABLE_CONFIGURATION_POLICY) 14 #if defined(ENABLE_CONFIGURATION_POLICY)
17 #include "components/policy/core/browser/browser_policy_connector.h" 15 #include "components/policy/core/browser/browser_policy_connector.h"
18 #include "components/policy/core/browser/configuration_policy_pref_store.h" 16 #include "components/policy/core/browser/configuration_policy_pref_store.h"
19 #include "components/policy/core/common/policy_service.h" 17 #include "components/policy/core/common/policy_service.h"
20 #include "components/policy/core/common/policy_types.h" 18 #include "components/policy/core/common/policy_types.h"
21 #endif 19 #endif
22 20
23 PrefServiceSyncableFactory::PrefServiceSyncableFactory() { 21 PrefServiceSyncableFactory::PrefServiceSyncableFactory()
24 } 22 : pref_model_associator_client_(nullptr) {}
25 23
26 PrefServiceSyncableFactory::~PrefServiceSyncableFactory() { 24 PrefServiceSyncableFactory::~PrefServiceSyncableFactory() {}
27 }
28 25
29 #if defined(ENABLE_CONFIGURATION_POLICY) 26 #if defined(ENABLE_CONFIGURATION_POLICY)
30 void PrefServiceSyncableFactory::SetManagedPolicies( 27 void PrefServiceSyncableFactory::SetManagedPolicies(
31 policy::PolicyService* service) { 28 policy::PolicyService* service,
29 policy::BrowserPolicyConnector* connector) {
32 set_managed_prefs( 30 set_managed_prefs(
33 new policy::ConfigurationPolicyPrefStore( 31 new policy::ConfigurationPolicyPrefStore(
34 service, 32 service,
35 g_browser_process->browser_policy_connector()->GetHandlerList(), 33 connector->GetHandlerList(),
36 policy::POLICY_LEVEL_MANDATORY)); 34 policy::POLICY_LEVEL_MANDATORY));
37 } 35 }
38 36
39 void PrefServiceSyncableFactory::SetRecommendedPolicies( 37 void PrefServiceSyncableFactory::SetRecommendedPolicies(
40 policy::PolicyService* service) { 38 policy::PolicyService* service,
39 policy::BrowserPolicyConnector* connector) {
41 set_recommended_prefs( 40 set_recommended_prefs(
42 new policy::ConfigurationPolicyPrefStore( 41 new policy::ConfigurationPolicyPrefStore(
43 service, 42 service,
44 g_browser_process->browser_policy_connector()->GetHandlerList(), 43 connector->GetHandlerList(),
45 policy::POLICY_LEVEL_RECOMMENDED)); 44 policy::POLICY_LEVEL_RECOMMENDED));
46 } 45 }
47 #endif 46 #endif
48 47
49 void PrefServiceSyncableFactory::SetCommandLine( 48 void PrefServiceSyncableFactory::SetPrefModelAssociatorClient(
50 base::CommandLine* command_line) { 49 PrefModelAssociatorClient* pref_model_associator_client) {
51 set_command_line_prefs(new CommandLinePrefStore(command_line)); 50 pref_model_associator_client_ = pref_model_associator_client;
52 } 51 }
53 52
54 scoped_ptr<PrefServiceSyncable> PrefServiceSyncableFactory::CreateSyncable( 53 scoped_ptr<PrefServiceSyncable> PrefServiceSyncableFactory::CreateSyncable(
55 user_prefs::PrefRegistrySyncable* pref_registry) { 54 user_prefs::PrefRegistrySyncable* pref_registry) {
56 TRACE_EVENT0("browser", "PrefServiceSyncableFactory::CreateSyncable"); 55 TRACE_EVENT0("browser", "PrefServiceSyncableFactory::CreateSyncable");
57 PrefNotifierImpl* pref_notifier = new PrefNotifierImpl(); 56 PrefNotifierImpl* pref_notifier = new PrefNotifierImpl();
58 scoped_ptr<PrefServiceSyncable> pref_service( 57 scoped_ptr<PrefServiceSyncable> pref_service(
59 new PrefServiceSyncable( 58 new PrefServiceSyncable(
60 pref_notifier, 59 pref_notifier,
61 new PrefValueStore(managed_prefs_.get(), 60 new PrefValueStore(managed_prefs_.get(),
62 supervised_user_prefs_.get(), 61 supervised_user_prefs_.get(),
63 extension_prefs_.get(), 62 extension_prefs_.get(),
64 command_line_prefs_.get(), 63 command_line_prefs_.get(),
65 user_prefs_.get(), 64 user_prefs_.get(),
66 recommended_prefs_.get(), 65 recommended_prefs_.get(),
67 pref_registry->defaults().get(), 66 pref_registry->defaults().get(),
68 pref_notifier), 67 pref_notifier),
69 user_prefs_.get(), 68 user_prefs_.get(),
70 pref_registry, 69 pref_registry,
71 read_error_callback_, 70 read_error_callback_,
72 async_)); 71 async_));
72 pref_service->SetPrefModelAssociatorClient(pref_model_associator_client_);
73 return pref_service.Pass(); 73 return pref_service.Pass();
74 } 74 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698