Index: sync/engine/sync_directory_update_handler.h |
diff --git a/sync/engine/sync_directory_update_handler.h b/sync/engine/sync_directory_update_handler.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..32ac7bfeb71838422f5c4668b594e1d4163a211f |
--- /dev/null |
+++ b/sync/engine/sync_directory_update_handler.h |
@@ -0,0 +1,83 @@ |
+// Copyright (c) 2013 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. |
+ |
+#ifndef SYNC_ENGINE_SYNC_DIRECTORY_UPDATE_HANDLER_H_ |
+#define SYNC_ENGINE_SYNC_DIRECTORY_UPDATE_HANDLER_H_ |
+ |
+#include <map> |
+ |
+#include "base/basictypes.h" |
+#include "base/gtest_prod_util.h" |
Nicolas Zea
2013/10/25 21:04:41
this isn't needed is it?
rlarocque
2013/10/25 22:29:47
Nope. Removed.
|
+#include "sync/base/sync_export.h" |
+#include "sync/engine/process_updates_util.h" |
+#include "sync/internal_api/public/base/model_type.h" |
+ |
+namespace sync_pb { |
+class DataTypeProgressMarker; |
+class GetUpdatesResponse; |
+} |
+ |
+namespace syncer { |
+ |
+namespace sessions { |
+class StatusController; |
+} |
+ |
+namespace syncable { |
+class Directory; |
+} |
+ |
+// This class represents the syncable::Directory's processes for requesting and |
+// processing updates from the sync server. |
+// |
+// Each instance of this class represents a particular type in the |
+// syncable::Directory. It can store and retreive that type's progress markers. |
+// It can also process a set of received SyncEntities and store their data. |
+class SYNC_EXPORT_PRIVATE SyncDirectoryUpdateHandler { |
Nicolas Zea
2013/10/25 21:04:41
Out of curiosity, is this eventually going to impl
rlarocque
2013/10/25 22:29:47
Mostly yes.
The final interface might need to be
|
+ public: |
+ SyncDirectoryUpdateHandler(syncable::Directory* dir, ModelType type); |
+ ~SyncDirectoryUpdateHandler(); |
+ |
+ // Returns the stored progress marker for this type. |
+ void GetDownloadProgress( |
Nicolas Zea
2013/10/25 21:04:41
Return rather than fill output parameter? Also, pe
rlarocque
2013/10/25 22:29:47
Fixed the comment.
The syncable::Directory's func
|
+ sync_pb::DataTypeProgressMarker* progress_marker) const; |
+ |
+ // Processes the contents of a GetUpdates response message. |
+ // |
+ // Should be invoked with the progress marker and set of SyncEntities from a |
+ // single GetUpdates response message. The progress marker's type must match |
+ // this update processor's type, and the set of SyncEntities must include all |
Nicolas Zea
2013/10/25 21:04:41
s/update processor/update handler/ ?
rlarocque
2013/10/25 22:29:47
Done. (Here and elsewhere.)
|
+ // entities of this type found in the response message. |
+ void ProcessGetUpdatesResponse( |
+ const sync_pb::DataTypeProgressMarker& progress_marker, |
+ const SyncEntityList& applicable_updates, |
+ sessions::StatusController* status); |
+ |
+ private: |
+ friend class SyncDirectoryUpdateHandlerTest; |
+ |
+ // Processes the given SyncEntities and stores their data in the directory. |
+ // Their types must match this update processor's type. |
+ void UpdateSyncEntities( |
+ syncable::ModelNeutralWriteTransaction* trans, |
+ const SyncEntityList& applicable_updates, |
+ sessions::StatusController* status); |
+ |
+ // Stores the given progress marker in the directory. |
+ // Its type must match this update processor's type. |
+ void UpdateProgressMarkers( |
Nicolas Zea
2013/10/25 21:04:41
Given that this only updates a single progress mar
rlarocque
2013/10/25 22:29:47
Done.
|
+ const sync_pb::DataTypeProgressMarker& progress_marker); |
+ |
+ syncable::Directory* dir_; |
+ ModelType type_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(SyncDirectoryUpdateHandler); |
+}; |
+ |
+// TODO(rlarocque): Find a better place to define this. |
+typedef std::map<ModelType, SyncDirectoryUpdateHandler*> UpdateHandlerMap; |
+ |
+} // namespace syncer |
+ |
+#endif // SYNC_ENGINE_SYNC_DIRECTORY_UPDATE_HANDLER_H_ |