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

Unified Diff: sync/notifier/sync_notifier_helper.cc

Issue 10702074: Refactor sync-specific parts out of SyncNotifier/SyncNotifierObserver (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Now with tests Created 8 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 side-by-side diff with in-line comments
Download patch
Index: sync/notifier/sync_notifier_helper.cc
diff --git a/sync/notifier/sync_notifier_helper.cc b/sync/notifier/sync_notifier_helper.cc
new file mode 100644
index 0000000000000000000000000000000000000000..3c7a026b1f749bc1e321664fef7ca24305c6e51d
--- /dev/null
+++ b/sync/notifier/sync_notifier_helper.cc
@@ -0,0 +1,74 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "sync/notifier/sync_notifier_helper.h"
+
+namespace syncer {
+
+SyncNotifierHelper::SyncNotifierHelper() {}
+
+ObjectIdSet SyncNotifierHelper::UpdateRegisteredIds(
+ SyncNotifierObserver* handler, const ObjectIdSet& ids) {
+ if (ids.empty()) {
+ handlers_.RemoveObserver(handler);
+ } else if (!handlers_.HasObserver(handler)) {
+ handlers_.AddObserver(handler);
+ }
+
+ ObjectIdSet registered_ids;
akalin 2012/07/20 19:01:40 why not just initialize registered_ids with ids?
akalin 2012/07/20 19:01:40 Add a comment here like: // Remove any existing e
dcheng 2012/07/21 00:09:54 Done.
dcheng 2012/07/21 00:09:54 Done.
+ for (ObjectIdObserverMap::iterator it = id_to_handler_map_.begin();
+ it != id_to_handler_map_.end(); ) {
+ if (it->second == handler) {
+ ObjectIdObserverMap::iterator erase_it = it;
+ ++it;
+ id_to_handler_map_.erase(erase_it);
+ } else {
+ registered_ids.insert(it->first);
+ ++it;
+ }
+ }
+
+ // Small optimization so we only traverse the map once when inserting entries.
akalin 2012/07/20 19:01:40 Then add a comment like: // Now add the new entri
akalin 2012/07/20 19:01:40 it's a bit unclear what the small optimization is.
dcheng 2012/07/21 00:09:54 Done.
dcheng 2012/07/21 00:09:54 Done.
+ ObjectIdObserverMap::iterator insert_it = id_to_handler_map_.begin();
+ for (ObjectIdSet::const_iterator it = ids.begin(); it != ids.end(); ++it) {
+ insert_it = id_to_handler_map_.insert(insert_it,
akalin 2012/07/20 19:01:40 this is dangerous since if an entry for the id alr
akalin 2012/07/20 19:34:38 Actually, on second thought, I think we should jus
dcheng 2012/07/21 00:09:54 Is there a way to make CHECKS non-fatal for unit t
dcheng 2012/07/21 00:09:54 Done with a variation.
+ std::make_pair(*it, handler));
+ }
+ registered_ids.insert(ids.begin(), ids.end());
+ return registered_ids;
akalin 2012/07/20 19:01:40 add a DCHECK somewhere (or a test in an "if (DEBUG
dcheng 2012/07/21 00:09:54 Done.
+}
+
+void SyncNotifierHelper::DispatchInvalidationsToHandlers(
+ const ObjectIdPayloadMap& id_payloads,
+ IncomingNotificationSource source) {
+ typedef std::map<SyncNotifierObserver*, ObjectIdPayloadMap> DispatchMap;
+ DispatchMap dispatch_map;
+ for (ObjectIdPayloadMap::const_iterator it = id_payloads.begin();
+ it != id_payloads.end(); ++it) {
+ ObjectIdObserverMap::const_iterator find_it =
+ id_to_handler_map_.find(it->first);
+ // If we get an invalidation with a source type that we can't map to an
+ // observer, just drop it--the observer was unregistered while the
+ // invalidation was in flight.
+ if (find_it == id_to_handler_map_.end())
+ continue;
+ dispatch_map[find_it->second].insert(*it);
+ }
+ for (std::map<SyncNotifierObserver*, ObjectIdPayloadMap>::const_iterator it =
akalin 2012/07/20 19:01:40 i think it's worth it to do a FOR_EACH_OBSERVER-st
akalin 2012/07/20 19:01:40 use the typedef here
dcheng 2012/07/21 00:09:54 Done.
dcheng 2012/07/21 00:09:54 I'd prefer not to dispatch invalidations with no a
+ dispatch_map.begin(); it != dispatch_map.end(); ++it) {
+ it->first->OnIncomingNotification(it->second, source);
+ }
+}
+
+void SyncNotifierHelper::OnNotificationsEnabled() {
+ FOR_EACH_OBSERVER(SyncNotifierObserver, handlers_, OnNotificationsEnabled());
+}
+
+void SyncNotifierHelper::OnNotificationsDisabled(
+ NotificationsDisabledReason reason) {
+ FOR_EACH_OBSERVER(SyncNotifierObserver, handlers_,
+ OnNotificationsDisabled(reason));
+}
+
+} // namespace syncer

Powered by Google App Engine
This is Rietveld 408576698