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

Side by Side Diff: sync/notifier/non_blocking_invalidator.cc

Issue 10911084: Implement Invalidator::Acknowledge (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 8 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "sync/notifier/non_blocking_invalidator.h" 5 #include "sync/notifier/non_blocking_invalidator.h"
6 6
7 #include <cstddef> 7 #include <cstddef>
8 8
9 #include "base/location.h" 9 #include "base/location.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
(...skipping 12 matching lines...) Expand all
23 public InvalidationHandler { 23 public InvalidationHandler {
24 public: 24 public:
25 // Called on parent thread. |delegate_observer| should be 25 // Called on parent thread. |delegate_observer| should be
26 // initialized. 26 // initialized.
27 explicit Core( 27 explicit Core(
28 const WeakHandle<InvalidationHandler>& delegate_observer); 28 const WeakHandle<InvalidationHandler>& delegate_observer);
29 29
30 // Helpers called on I/O thread. 30 // Helpers called on I/O thread.
31 void Initialize( 31 void Initialize(
32 const notifier::NotifierOptions& notifier_options, 32 const notifier::NotifierOptions& notifier_options,
33 const InvalidationVersionMap& initial_max_invalidation_versions, 33 const InvalidationStateMap& initial_invalidation_state_map,
34 const std::string& initial_invalidation_state, 34 const std::string& initial_invalidation_state,
35 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker, 35 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker,
36 const std::string& client_info); 36 const std::string& client_info);
37 void Teardown(); 37 void Teardown();
38 void UpdateRegisteredIds(const ObjectIdSet& ids); 38 void UpdateRegisteredIds(const ObjectIdSet& ids);
39 void Acknowledge(const invalidation::ObjectId& id,
40 const AckHandle& ack_handle);
39 void SetUniqueId(const std::string& unique_id); 41 void SetUniqueId(const std::string& unique_id);
40 void SetStateDeprecated(const std::string& state); 42 void SetStateDeprecated(const std::string& state);
41 void UpdateCredentials(const std::string& email, const std::string& token); 43 void UpdateCredentials(const std::string& email, const std::string& token);
42 44
43 // InvalidationHandler implementation (all called on I/O thread by 45 // InvalidationHandler implementation (all called on I/O thread by
44 // InvalidationNotifier). 46 // InvalidationNotifier).
45 virtual void OnInvalidatorStateChange(InvalidatorState reason) OVERRIDE; 47 virtual void OnInvalidatorStateChange(InvalidatorState reason) OVERRIDE;
46 virtual void OnIncomingInvalidation( 48 virtual void OnIncomingInvalidation(
47 const ObjectIdStateMap& id_state_map, 49 const ObjectIdStateMap& id_state_map,
48 IncomingInvalidationSource source) OVERRIDE; 50 IncomingInvalidationSource source) OVERRIDE;
(...skipping 16 matching lines...) Expand all
65 const WeakHandle<InvalidationHandler>& delegate_observer) 67 const WeakHandle<InvalidationHandler>& delegate_observer)
66 : delegate_observer_(delegate_observer) { 68 : delegate_observer_(delegate_observer) {
67 DCHECK(delegate_observer_.IsInitialized()); 69 DCHECK(delegate_observer_.IsInitialized());
68 } 70 }
69 71
70 NonBlockingInvalidator::Core::~Core() { 72 NonBlockingInvalidator::Core::~Core() {
71 } 73 }
72 74
73 void NonBlockingInvalidator::Core::Initialize( 75 void NonBlockingInvalidator::Core::Initialize(
74 const notifier::NotifierOptions& notifier_options, 76 const notifier::NotifierOptions& notifier_options,
75 const InvalidationVersionMap& initial_max_invalidation_versions, 77 const InvalidationStateMap& initial_invalidation_state_map,
76 const std::string& initial_invalidation_state, 78 const std::string& initial_invalidation_state,
77 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker, 79 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker,
78 const std::string& client_info) { 80 const std::string& client_info) {
79 DCHECK(notifier_options.request_context_getter); 81 DCHECK(notifier_options.request_context_getter);
80 DCHECK_EQ(notifier::NOTIFICATION_SERVER, 82 DCHECK_EQ(notifier::NOTIFICATION_SERVER,
81 notifier_options.notification_method); 83 notifier_options.notification_method);
82 network_task_runner_ = notifier_options.request_context_getter-> 84 network_task_runner_ = notifier_options.request_context_getter->
83 GetNetworkTaskRunner(); 85 GetNetworkTaskRunner();
84 DCHECK(network_task_runner_->BelongsToCurrentThread()); 86 DCHECK(network_task_runner_->BelongsToCurrentThread());
85 invalidation_notifier_.reset( 87 invalidation_notifier_.reset(
86 new InvalidationNotifier( 88 new InvalidationNotifier(
87 notifier::PushClient::CreateDefaultOnIOThread(notifier_options), 89 notifier::PushClient::CreateDefaultOnIOThread(notifier_options),
88 initial_max_invalidation_versions, 90 initial_invalidation_state_map,
89 initial_invalidation_state, 91 initial_invalidation_state,
90 invalidation_state_tracker, 92 invalidation_state_tracker,
91 client_info)); 93 client_info));
92 invalidation_notifier_->RegisterHandler(this); 94 invalidation_notifier_->RegisterHandler(this);
93 } 95 }
94 96
95 void NonBlockingInvalidator::Core::Teardown() { 97 void NonBlockingInvalidator::Core::Teardown() {
96 DCHECK(network_task_runner_->BelongsToCurrentThread()); 98 DCHECK(network_task_runner_->BelongsToCurrentThread());
97 invalidation_notifier_->UnregisterHandler(this); 99 invalidation_notifier_->UnregisterHandler(this);
98 invalidation_notifier_.reset(); 100 invalidation_notifier_.reset();
99 network_task_runner_ = NULL; 101 network_task_runner_ = NULL;
100 } 102 }
101 103
102 void NonBlockingInvalidator::Core::UpdateRegisteredIds(const ObjectIdSet& ids) { 104 void NonBlockingInvalidator::Core::UpdateRegisteredIds(const ObjectIdSet& ids) {
103 DCHECK(network_task_runner_->BelongsToCurrentThread()); 105 DCHECK(network_task_runner_->BelongsToCurrentThread());
104 invalidation_notifier_->UpdateRegisteredIds(this, ids); 106 invalidation_notifier_->UpdateRegisteredIds(this, ids);
105 } 107 }
106 108
109 void NonBlockingInvalidator::Core::Acknowledge(const invalidation::ObjectId& id,
110 const AckHandle& ack_handle) {
111 DCHECK(network_task_runner_->BelongsToCurrentThread());
112 invalidation_notifier_->Acknowledge(id, ack_handle);
113 }
114
107 void NonBlockingInvalidator::Core::SetUniqueId(const std::string& unique_id) { 115 void NonBlockingInvalidator::Core::SetUniqueId(const std::string& unique_id) {
108 DCHECK(network_task_runner_->BelongsToCurrentThread()); 116 DCHECK(network_task_runner_->BelongsToCurrentThread());
109 invalidation_notifier_->SetUniqueId(unique_id); 117 invalidation_notifier_->SetUniqueId(unique_id);
110 } 118 }
111 119
112 void NonBlockingInvalidator::Core::SetStateDeprecated( 120 void NonBlockingInvalidator::Core::SetStateDeprecated(
113 const std::string& state) { 121 const std::string& state) {
114 DCHECK(network_task_runner_->BelongsToCurrentThread()); 122 DCHECK(network_task_runner_->BelongsToCurrentThread());
115 invalidation_notifier_->SetStateDeprecated(state); 123 invalidation_notifier_->SetStateDeprecated(state);
116 } 124 }
(...skipping 15 matching lines...) Expand all
132 const ObjectIdStateMap& id_state_map, IncomingInvalidationSource source) { 140 const ObjectIdStateMap& id_state_map, IncomingInvalidationSource source) {
133 DCHECK(network_task_runner_->BelongsToCurrentThread()); 141 DCHECK(network_task_runner_->BelongsToCurrentThread());
134 delegate_observer_.Call(FROM_HERE, 142 delegate_observer_.Call(FROM_HERE,
135 &InvalidationHandler::OnIncomingInvalidation, 143 &InvalidationHandler::OnIncomingInvalidation,
136 id_state_map, 144 id_state_map,
137 source); 145 source);
138 } 146 }
139 147
140 NonBlockingInvalidator::NonBlockingInvalidator( 148 NonBlockingInvalidator::NonBlockingInvalidator(
141 const notifier::NotifierOptions& notifier_options, 149 const notifier::NotifierOptions& notifier_options,
142 const InvalidationVersionMap& initial_max_invalidation_versions, 150 const InvalidationStateMap& initial_invalidation_state_map,
143 const std::string& initial_invalidation_state, 151 const std::string& initial_invalidation_state,
144 const WeakHandle<InvalidationStateTracker>& 152 const WeakHandle<InvalidationStateTracker>&
145 invalidation_state_tracker, 153 invalidation_state_tracker,
146 const std::string& client_info) 154 const std::string& client_info)
147 : weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)), 155 : weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)),
148 core_( 156 core_(
149 new Core(MakeWeakHandle(weak_ptr_factory_.GetWeakPtr()))), 157 new Core(MakeWeakHandle(weak_ptr_factory_.GetWeakPtr()))),
150 parent_task_runner_( 158 parent_task_runner_(
151 base::ThreadTaskRunnerHandle::Get()), 159 base::ThreadTaskRunnerHandle::Get()),
152 network_task_runner_(notifier_options.request_context_getter-> 160 network_task_runner_(notifier_options.request_context_getter->
153 GetNetworkTaskRunner()) { 161 GetNetworkTaskRunner()) {
154 if (!network_task_runner_->PostTask( 162 if (!network_task_runner_->PostTask(
155 FROM_HERE, 163 FROM_HERE,
156 base::Bind( 164 base::Bind(
157 &NonBlockingInvalidator::Core::Initialize, 165 &NonBlockingInvalidator::Core::Initialize,
158 core_.get(), 166 core_.get(),
159 notifier_options, 167 notifier_options,
160 initial_max_invalidation_versions, 168 initial_invalidation_state_map,
161 initial_invalidation_state, 169 initial_invalidation_state,
162 invalidation_state_tracker, 170 invalidation_state_tracker,
163 client_info))) { 171 client_info))) {
164 NOTREACHED(); 172 NOTREACHED();
165 } 173 }
166 } 174 }
167 175
168 NonBlockingInvalidator::~NonBlockingInvalidator() { 176 NonBlockingInvalidator::~NonBlockingInvalidator() {
169 DCHECK(parent_task_runner_->BelongsToCurrentThread()); 177 DCHECK(parent_task_runner_->BelongsToCurrentThread());
170 if (!network_task_runner_->PostTask( 178 if (!network_task_runner_->PostTask(
(...skipping 20 matching lines...) Expand all
191 core_.get(), 199 core_.get(),
192 registrar_.GetAllRegisteredIds()))) { 200 registrar_.GetAllRegisteredIds()))) {
193 NOTREACHED(); 201 NOTREACHED();
194 } 202 }
195 } 203 }
196 204
197 void NonBlockingInvalidator::UnregisterHandler(InvalidationHandler* handler) { 205 void NonBlockingInvalidator::UnregisterHandler(InvalidationHandler* handler) {
198 DCHECK(parent_task_runner_->BelongsToCurrentThread()); 206 DCHECK(parent_task_runner_->BelongsToCurrentThread());
199 registrar_.UnregisterHandler(handler); 207 registrar_.UnregisterHandler(handler);
200 } 208 }
201 209
Pete Williamson 2012/09/14 18:28:22 This travels through a lot of levels. What does a
dcheng 2012/09/14 19:08:49 It would be easier to explain this in person rathe
210 void NonBlockingInvalidator::Acknowledge(const invalidation::ObjectId& id,
211 const AckHandle& ack_handle) {
212 DCHECK(parent_task_runner_->BelongsToCurrentThread());
213 if (!network_task_runner_->PostTask(
214 FROM_HERE,
215 base::Bind(
216 &NonBlockingInvalidator::Core::Acknowledge,
217 core_.get(),
218 id,
219 ack_handle))) {
220 NOTREACHED();
221 }
222 }
223
202 InvalidatorState NonBlockingInvalidator::GetInvalidatorState() const { 224 InvalidatorState NonBlockingInvalidator::GetInvalidatorState() const {
203 DCHECK(parent_task_runner_->BelongsToCurrentThread()); 225 DCHECK(parent_task_runner_->BelongsToCurrentThread());
204 return registrar_.GetInvalidatorState(); 226 return registrar_.GetInvalidatorState();
205 } 227 }
206 228
207 void NonBlockingInvalidator::SetUniqueId(const std::string& unique_id) { 229 void NonBlockingInvalidator::SetUniqueId(const std::string& unique_id) {
208 DCHECK(parent_task_runner_->BelongsToCurrentThread()); 230 DCHECK(parent_task_runner_->BelongsToCurrentThread());
209 if (!network_task_runner_->PostTask( 231 if (!network_task_runner_->PostTask(
210 FROM_HERE, 232 FROM_HERE,
211 base::Bind(&NonBlockingInvalidator::Core::SetUniqueId, 233 base::Bind(&NonBlockingInvalidator::Core::SetUniqueId,
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
249 } 271 }
250 272
251 void NonBlockingInvalidator::OnIncomingInvalidation( 273 void NonBlockingInvalidator::OnIncomingInvalidation(
252 const ObjectIdStateMap& id_state_map, 274 const ObjectIdStateMap& id_state_map,
253 IncomingInvalidationSource source) { 275 IncomingInvalidationSource source) {
254 DCHECK(parent_task_runner_->BelongsToCurrentThread()); 276 DCHECK(parent_task_runner_->BelongsToCurrentThread());
255 registrar_.DispatchInvalidationsToHandlers(id_state_map, source); 277 registrar_.DispatchInvalidationsToHandlers(id_state_map, source);
256 } 278 }
257 279
258 } // namespace syncer 280 } // namespace syncer
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698