OLD | NEW |
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/policy/configuration_policy_provider.h" | 5 #include "chrome/browser/policy/configuration_policy_provider.h" |
6 | 6 |
7 #include "chrome/browser/policy/policy_map.h" | 7 #include "chrome/browser/policy/policy_map.h" |
8 | 8 |
9 namespace policy { | 9 namespace policy { |
10 | 10 |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
44 void ConfigurationPolicyProvider::OverridePolicies(PolicyMap* policies) { | 44 void ConfigurationPolicyProvider::OverridePolicies(PolicyMap* policies) { |
45 override_policies_.reset(policies); | 45 override_policies_.reset(policies); |
46 NotifyPolicyUpdated(); | 46 NotifyPolicyUpdated(); |
47 } | 47 } |
48 | 48 |
49 #endif | 49 #endif |
50 | 50 |
51 void ConfigurationPolicyProvider::NotifyPolicyUpdated() { | 51 void ConfigurationPolicyProvider::NotifyPolicyUpdated() { |
52 FOR_EACH_OBSERVER(ConfigurationPolicyProvider::Observer, | 52 FOR_EACH_OBSERVER(ConfigurationPolicyProvider::Observer, |
53 observer_list_, | 53 observer_list_, |
54 OnUpdatePolicy()); | 54 OnUpdatePolicy(this)); |
55 } | 55 } |
56 | 56 |
57 void ConfigurationPolicyProvider::AddObserver(Observer* observer) { | 57 void ConfigurationPolicyProvider::AddObserver(Observer* observer) { |
58 observer_list_.AddObserver(observer); | 58 observer_list_.AddObserver(observer); |
59 } | 59 } |
60 | 60 |
61 void ConfigurationPolicyProvider::RemoveObserver(Observer* observer) { | 61 void ConfigurationPolicyProvider::RemoveObserver(Observer* observer) { |
62 observer_list_.RemoveObserver(observer); | 62 observer_list_.RemoveObserver(observer); |
63 } | 63 } |
64 | 64 |
65 // Class ConfigurationPolicyObserverRegistrar. | 65 // Class ConfigurationPolicyObserverRegistrar. |
66 | 66 |
67 ConfigurationPolicyObserverRegistrar::ConfigurationPolicyObserverRegistrar() | 67 ConfigurationPolicyObserverRegistrar::ConfigurationPolicyObserverRegistrar() |
68 : provider_(NULL), | 68 : provider_(NULL), |
69 observer_(NULL) {} | 69 observer_(NULL) {} |
70 | 70 |
71 ConfigurationPolicyObserverRegistrar::~ConfigurationPolicyObserverRegistrar() { | 71 ConfigurationPolicyObserverRegistrar::~ConfigurationPolicyObserverRegistrar() { |
72 if (provider_) | 72 if (provider_) |
73 provider_->RemoveObserver(this); | 73 provider_->RemoveObserver(this); |
74 } | 74 } |
75 | 75 |
76 void ConfigurationPolicyObserverRegistrar::Init( | 76 void ConfigurationPolicyObserverRegistrar::Init( |
77 ConfigurationPolicyProvider* provider, | 77 ConfigurationPolicyProvider* provider, |
78 ConfigurationPolicyProvider::Observer* observer) { | 78 ConfigurationPolicyProvider::Observer* observer) { |
79 provider_ = provider; | 79 provider_ = provider; |
80 observer_ = observer; | 80 observer_ = observer; |
81 provider_->AddObserver(this); | 81 provider_->AddObserver(this); |
82 } | 82 } |
83 | 83 |
84 void ConfigurationPolicyObserverRegistrar::OnUpdatePolicy() { | 84 void ConfigurationPolicyObserverRegistrar::OnUpdatePolicy( |
85 observer_->OnUpdatePolicy(); | 85 ConfigurationPolicyProvider* provider) { |
| 86 DCHECK_EQ(provider_, provider); |
| 87 observer_->OnUpdatePolicy(provider_); |
86 } | 88 } |
87 | 89 |
88 void ConfigurationPolicyObserverRegistrar::OnProviderGoingAway() { | 90 void ConfigurationPolicyObserverRegistrar::OnProviderGoingAway() { |
89 observer_->OnProviderGoingAway(); | 91 observer_->OnProviderGoingAway(); |
90 provider_->RemoveObserver(this); | 92 provider_->RemoveObserver(this); |
91 provider_ = NULL; | 93 provider_ = NULL; |
92 } | 94 } |
93 | 95 |
94 } // namespace policy | 96 } // namespace policy |
OLD | NEW |