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

Side by Side Diff: chrome/browser/net/pref_proxy_config_service.cc

Issue 7327007: Moving notification types which are chrome specific to a new header file chrome_notification_type... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 5 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 | 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/net/pref_proxy_config_service.h" 5 #include "chrome/browser/net/pref_proxy_config_service.h"
6 6
7 #include "base/values.h" 7 #include "base/values.h"
8 #include "chrome/browser/prefs/pref_service.h" 8 #include "chrome/browser/prefs/pref_service.h"
9 #include "chrome/browser/prefs/pref_set_observer.h" 9 #include "chrome/browser/prefs/pref_set_observer.h"
10 #include "chrome/browser/prefs/proxy_config_dictionary.h" 10 #include "chrome/browser/prefs/proxy_config_dictionary.h"
11 #include "chrome/common/chrome_notification_types.h"
11 #include "chrome/common/pref_names.h" 12 #include "chrome/common/pref_names.h"
12 #include "content/browser/browser_thread.h" 13 #include "content/browser/browser_thread.h"
13 #include "content/common/notification_details.h" 14 #include "content/common/notification_details.h"
14 #include "content/common/notification_source.h" 15 #include "content/common/notification_source.h"
15 #include "content/common/notification_type.h"
16 16
17 PrefProxyConfigTracker::PrefProxyConfigTracker(PrefService* pref_service) 17 PrefProxyConfigTracker::PrefProxyConfigTracker(PrefService* pref_service)
18 : pref_service_(pref_service) { 18 : pref_service_(pref_service) {
19 config_state_ = ReadPrefConfig(&pref_config_); 19 config_state_ = ReadPrefConfig(&pref_config_);
20 proxy_prefs_observer_.reset( 20 proxy_prefs_observer_.reset(
21 PrefSetObserver::CreateProxyPrefSetObserver(pref_service_, this)); 21 PrefSetObserver::CreateProxyPrefSetObserver(pref_service_, this));
22 } 22 }
23 23
24 PrefProxyConfigTracker::~PrefProxyConfigTracker() { 24 PrefProxyConfigTracker::~PrefProxyConfigTracker() {
25 DCHECK(pref_service_ == NULL); 25 DCHECK(pref_service_ == NULL);
(...skipping 19 matching lines...) Expand all
45 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 45 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
46 observers_.AddObserver(observer); 46 observers_.AddObserver(observer);
47 } 47 }
48 48
49 void PrefProxyConfigTracker::RemoveObserver( 49 void PrefProxyConfigTracker::RemoveObserver(
50 PrefProxyConfigTracker::Observer* observer) { 50 PrefProxyConfigTracker::Observer* observer) {
51 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 51 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
52 observers_.RemoveObserver(observer); 52 observers_.RemoveObserver(observer);
53 } 53 }
54 54
55 void PrefProxyConfigTracker::Observe(NotificationType type, 55 void PrefProxyConfigTracker::Observe(int type,
56 const NotificationSource& source, 56 const NotificationSource& source,
57 const NotificationDetails& details) { 57 const NotificationDetails& details) {
58 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 58 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
59 if (type == NotificationType::PREF_CHANGED && 59 if (type == chrome::NOTIFICATION_PREF_CHANGED &&
60 Source<PrefService>(source).ptr() == pref_service_) { 60 Source<PrefService>(source).ptr() == pref_service_) {
61 net::ProxyConfig new_config; 61 net::ProxyConfig new_config;
62 ConfigState config_state = ReadPrefConfig(&new_config); 62 ConfigState config_state = ReadPrefConfig(&new_config);
63 BrowserThread::PostTask( 63 BrowserThread::PostTask(
64 BrowserThread::IO, FROM_HERE, 64 BrowserThread::IO, FROM_HERE,
65 NewRunnableMethod(this, 65 NewRunnableMethod(this,
66 &PrefProxyConfigTracker::InstallProxyConfig, 66 &PrefProxyConfigTracker::InstallProxyConfig,
67 new_config, config_state)); 67 new_config, config_state));
68 } else { 68 } else {
69 NOTREACHED() << "Unexpected notification of type " << type.value; 69 NOTREACHED() << "Unexpected notification of type " << type;
70 } 70 }
71 } 71 }
72 72
73 void PrefProxyConfigTracker::InstallProxyConfig( 73 void PrefProxyConfigTracker::InstallProxyConfig(
74 const net::ProxyConfig& config, 74 const net::ProxyConfig& config,
75 PrefProxyConfigTracker::ConfigState config_state) { 75 PrefProxyConfigTracker::ConfigState config_state) {
76 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 76 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
77 if (config_state_ != config_state || 77 if (config_state_ != config_state ||
78 (config_state_ != CONFIG_UNSET && !pref_config_.Equals(config))) { 78 (config_state_ != CONFIG_UNSET && !pref_config_.Equals(config))) {
79 config_state_ = config_state; 79 config_state_ = config_state;
(...skipping 188 matching lines...) Expand 10 before | Expand all | Expand 10 after
268 } 268 }
269 } 269 }
270 270
271 // static 271 // static
272 void PrefProxyConfigService::RegisterPrefs(PrefService* pref_service) { 272 void PrefProxyConfigService::RegisterPrefs(PrefService* pref_service) {
273 DictionaryValue* default_settings = ProxyConfigDictionary::CreateSystem(); 273 DictionaryValue* default_settings = ProxyConfigDictionary::CreateSystem();
274 pref_service->RegisterDictionaryPref(prefs::kProxy, 274 pref_service->RegisterDictionaryPref(prefs::kProxy,
275 default_settings, 275 default_settings,
276 PrefService::UNSYNCABLE_PREF); 276 PrefService::UNSYNCABLE_PREF);
277 } 277 }
OLDNEW
« no previous file with comments | « chrome/browser/net/pref_proxy_config_service.h ('k') | chrome/browser/net/ssl_config_service_manager_pref.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698