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

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

Issue 8568019: Introduce per-tab preferences service. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Comments addressed Created 9 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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.h" 5 #include "chrome/browser/prefs/pref_service.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <string> 8 #include <string>
9 9
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "base/command_line.h" 11 #include "base/command_line.h"
12 #include "base/file_path.h" 12 #include "base/file_path.h"
13 #include "base/file_util.h" 13 #include "base/file_util.h"
14 #include "base/logging.h" 14 #include "base/logging.h"
15 #include "base/message_loop.h" 15 #include "base/message_loop.h"
16 #include "base/metrics/histogram.h" 16 #include "base/metrics/histogram.h"
17 #include "base/stl_util.h" 17 #include "base/stl_util.h"
18 #include "base/string_number_conversions.h" 18 #include "base/string_number_conversions.h"
19 #include "base/string_util.h" 19 #include "base/string_util.h"
20 #include "base/value_conversions.h" 20 #include "base/value_conversions.h"
21 #include "build/build_config.h" 21 #include "build/build_config.h"
22 #include "chrome/browser/browser_process.h" 22 #include "chrome/browser/browser_process.h"
23 #include "chrome/browser/extensions/extension_pref_store.h" 23 #include "chrome/browser/extensions/extension_pref_store.h"
24 #include "chrome/browser/policy/configuration_policy_pref_store.h" 24 #include "chrome/browser/policy/configuration_policy_pref_store.h"
25 #include "chrome/browser/prefs/command_line_pref_store.h" 25 #include "chrome/browser/prefs/command_line_pref_store.h"
26 #include "chrome/browser/prefs/default_pref_store.h" 26 #include "chrome/browser/prefs/default_pref_store.h"
27 #include "chrome/browser/prefs/incognito_user_pref_store.h" 27 #include "chrome/browser/prefs/incognito_user_pref_store.h"
28 #include "chrome/browser/prefs/per_tab_user_pref_store.h"
28 #include "chrome/browser/prefs/pref_model_associator.h" 29 #include "chrome/browser/prefs/pref_model_associator.h"
29 #include "chrome/browser/prefs/pref_notifier_impl.h" 30 #include "chrome/browser/prefs/pref_notifier_impl.h"
30 #include "chrome/browser/prefs/pref_value_store.h" 31 #include "chrome/browser/prefs/pref_value_store.h"
31 #include "chrome/browser/ui/profile_error_dialog.h" 32 #include "chrome/browser/ui/profile_error_dialog.h"
32 #include "chrome/common/json_pref_store.h" 33 #include "chrome/common/json_pref_store.h"
33 #include "content/public/browser/browser_thread.h" 34 #include "content/public/browser/browser_thread.h"
34 #include "grit/chromium_strings.h" 35 #include "grit/chromium_strings.h"
35 #include "grit/generated_resources.h" 36 #include "grit/generated_resources.h"
36 #include "ui/base/l10n/l10n_util.h" 37 #include "ui/base/l10n/l10n_util.h"
37 38
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after
145 ConfigurationPolicyPrefStore* managed_cloud = NULL; 146 ConfigurationPolicyPrefStore* managed_cloud = NULL;
146 ConfigurationPolicyPrefStore* recommended_platform = NULL; 147 ConfigurationPolicyPrefStore* recommended_platform = NULL;
147 ConfigurationPolicyPrefStore* recommended_cloud = NULL; 148 ConfigurationPolicyPrefStore* recommended_cloud = NULL;
148 #endif // ENABLE_CONFIGURATION_POLICY 149 #endif // ENABLE_CONFIGURATION_POLICY
149 150
150 CommandLinePrefStore* command_line = 151 CommandLinePrefStore* command_line =
151 new CommandLinePrefStore(CommandLine::ForCurrentProcess()); 152 new CommandLinePrefStore(CommandLine::ForCurrentProcess());
152 JsonPrefStore* user = new JsonPrefStore( 153 JsonPrefStore* user = new JsonPrefStore(
153 pref_filename, 154 pref_filename,
154 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::FILE)); 155 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::FILE));
155 DefaultPrefStore* default_pref_store = new DefaultPrefStore();
156 156
157 return new PrefService( 157 return new PrefService(
158 managed_platform, managed_cloud, extension_prefs, 158 managed_platform,
159 command_line, user, recommended_platform, 159 managed_cloud,
160 recommended_cloud, default_pref_store, async); 160 extension_prefs,
161 command_line,
162 user,
163 recommended_platform,
164 recommended_cloud,
165 async);
161 } 166 }
162 167
163 PrefService* PrefService::CreateIncognitoPrefService( 168 PrefService* PrefService::CreateIncognitoPrefService(
164 PrefStore* incognito_extension_prefs) { 169 PrefStore* incognito_extension_prefs) {
165 return new PrefService(*this, incognito_extension_prefs); 170 return new PrefService(
171 pref_value_store_.get(),
172 NULL, // managed_platform_prefs
173 NULL, // managed_cloud_prefs
174 incognito_extension_prefs,
175 NULL, // command_line_prefs
176 new IncognitoUserPrefStore(user_pref_store_.get()),
177 NULL, // recommended_platform_prefs
178 NULL, // recommended_cloud_prefs
179 default_store_.get());
Mattias Nissler (ping if slow) 2011/11/17 18:44:39 You pass in the default store as the async paramet
mnaganov (inactive) 2011/11/17 19:53:32 I hope no. Those two constructors differ by the nu
180 }
181
182 PrefService* PrefService::CreatePrefServiceWithPerTabPrefStore() {
183 return new PrefService(
184 pref_value_store_.get(),
185 NULL, // managed_platform_prefs
186 NULL, // managed_cloud_prefs
187 NULL, // extension_prefs
188 NULL, // command_line_prefs
189 new PerTabUserPrefStore(user_pref_store_.get()),
190 NULL, // recommended_platform_prefs
191 NULL, // recommended_cloud_prefs
192 new DefaultPrefStore());
166 } 193 }
167 194
168 PrefService::PrefService(PrefStore* managed_platform_prefs, 195 PrefService::PrefService(PrefStore* managed_platform_prefs,
169 PrefStore* managed_cloud_prefs, 196 PrefStore* managed_cloud_prefs,
170 PrefStore* extension_prefs, 197 PrefStore* extension_prefs,
171 PrefStore* command_line_prefs, 198 PrefStore* command_line_prefs,
172 PersistentPrefStore* user_prefs, 199 PersistentPrefStore* user_prefs,
173 PrefStore* recommended_platform_prefs, 200 PrefStore* recommended_platform_prefs,
174 PrefStore* recommended_cloud_prefs, 201 PrefStore* recommended_cloud_prefs,
175 DefaultPrefStore* default_store,
176 bool async) 202 bool async)
177 : user_pref_store_(user_prefs), 203 : pref_notifier_(new PrefNotifierImpl(this)),
178 default_store_(default_store) { 204 user_pref_store_(user_prefs),
179 pref_sync_associator_.reset(new PrefModelAssociator(this)); 205 default_store_(new DefaultPrefStore()),
Mattias Nissler (ping if slow) 2011/11/17 18:44:39 As I mentioned above, that'll break the incognito
mnaganov (inactive) 2011/11/17 19:53:32 Ditto. For the incognito mode, the second construc
180 pref_notifier_.reset(new PrefNotifierImpl(this)); 206 pref_sync_associator_(new PrefModelAssociator(this)),
181 pref_value_store_.reset( 207 pref_value_store_(new PrefValueStore(
182 new PrefValueStore(managed_platform_prefs, 208 managed_platform_prefs,
183 managed_cloud_prefs, 209 managed_cloud_prefs,
184 extension_prefs, 210 extension_prefs,
185 command_line_prefs, 211 command_line_prefs,
186 user_pref_store_, 212 user_prefs,
187 recommended_platform_prefs, 213 recommended_platform_prefs,
188 recommended_cloud_prefs, 214 recommended_cloud_prefs,
189 default_store, 215 default_store_,
190 pref_sync_associator_.get(), 216 pref_sync_associator_.get(),
191 pref_notifier_.get())); 217 pref_notifier_.get())) {
192 InitFromStorage(async); 218 InitFromStorage(async);
193 } 219 }
194 220
195 PrefService::PrefService(const PrefService& original, 221 PrefService::PrefService(PrefValueStore* source_store,
196 PrefStore* incognito_extension_prefs) 222 PrefStore* managed_platform_prefs,
197 : user_pref_store_( 223 PrefStore* managed_cloud_prefs,
198 new IncognitoUserPrefStore(original.user_pref_store_.get())), 224 PrefStore* extension_prefs,
199 default_store_(original.default_store_.get()) { 225 PrefStore* command_line_prefs,
200 // Incognito mode doesn't sync, so no need to create PrefModelAssociator. 226 PersistentPrefStore* user_prefs,
201 pref_notifier_.reset(new PrefNotifierImpl(this)); 227 PrefStore* recommended_platform_prefs,
202 pref_value_store_.reset(original.pref_value_store_->CloneAndSpecialize( 228 PrefStore* recommended_cloud_prefs,
203 NULL, // managed_platform_prefs 229 DefaultPrefStore* default_store)
204 NULL, // managed_cloud_prefs 230 : pref_notifier_(new PrefNotifierImpl(this)),
205 incognito_extension_prefs, 231 user_pref_store_(user_prefs),
206 NULL, // command_line_prefs 232 default_store_(default_store),
207 user_pref_store_.get(), 233 pref_sync_associator_(NULL),
208 NULL, // recommended_platform_prefs 234 pref_value_store_(source_store->CloneAndSpecialize(
209 NULL, // recommended_cloud_prefs 235 managed_platform_prefs,
210 default_store_.get(), 236 managed_cloud_prefs,
211 NULL, // pref_sync_associator_ 237 extension_prefs,
212 pref_notifier_.get())); 238 command_line_prefs,
239 user_prefs,
240 recommended_platform_prefs,
241 recommended_cloud_prefs,
242 default_store_,
243 pref_sync_associator_.get(),
244 pref_notifier_.get())) {
245 InitFromStorage(false);
213 } 246 }
214 247
215 PrefService::~PrefService() { 248 PrefService::~PrefService() {
216 DCHECK(CalledOnValidThread()); 249 DCHECK(CalledOnValidThread());
217 STLDeleteContainerPointers(prefs_.begin(), prefs_.end()); 250 STLDeleteContainerPointers(prefs_.begin(), prefs_.end());
218 prefs_.clear(); 251 prefs_.clear();
219 252
220 // Reset pointers so accesses after destruction reliably crash. 253 // Reset pointers so accesses after destruction reliably crash.
221 pref_value_store_.reset(); 254 pref_value_store_.reset();
222 user_pref_store_ = NULL; 255 user_pref_store_ = NULL;
(...skipping 674 matching lines...) Expand 10 before | Expand all | Expand 10 after
897 return pref_value_store()->PrefValueFromDefaultStore(name_.c_str()); 930 return pref_value_store()->PrefValueFromDefaultStore(name_.c_str());
898 } 931 }
899 932
900 bool PrefService::Preference::IsUserModifiable() const { 933 bool PrefService::Preference::IsUserModifiable() const {
901 return pref_value_store()->PrefValueUserModifiable(name_.c_str()); 934 return pref_value_store()->PrefValueUserModifiable(name_.c_str());
902 } 935 }
903 936
904 bool PrefService::Preference::IsExtensionModifiable() const { 937 bool PrefService::Preference::IsExtensionModifiable() const {
905 return pref_value_store()->PrefValueExtensionModifiable(name_.c_str()); 938 return pref_value_store()->PrefValueExtensionModifiable(name_.c_str());
906 } 939 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698