Chromium Code Reviews| Index: sync/engine/update_handler.h |
| diff --git a/sync/engine/update_handler.h b/sync/engine/update_handler.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..90457616e647f20a932a343e3b7010a40f24f3c6 |
| --- /dev/null |
| +++ b/sync/engine/update_handler.h |
| @@ -0,0 +1,61 @@ |
| +// Copyright 2014 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_UPDATE_HANDLER_H_ |
| +#define SYNC_ENGINE_UPDATE_HANDLER_H_ |
| + |
| +#include <vector> |
| + |
| +#include "sync/base/sync_export.h" |
| + |
| +namespace sync_pb { |
| +class DataTypeProgressMarker; |
| +class SyncEntity; |
| +} |
| + |
| +typedef std::vector<const sync_pb::SyncEntity*> SyncEntityList; |
| + |
| +namespace syncer { |
| + |
| +namespace sessions { |
| +class StatusController; |
| +} |
| + |
| +class ModelSafeWorker; |
| + |
| +// This class represents an entity that can request and receive updates from the |
| +// sync server. |
|
tim (not reviewing)
2014/02/18 19:15:01
"...request, receive, and apply updates from the s
rlarocque
2014/02/18 20:01:13
Done.
|
| +class SYNC_EXPORT_PRIVATE UpdateHandler { |
| + public: |
| + UpdateHandler(); |
| + virtual ~UpdateHandler() = 0; |
| + |
| + // Fills the given parameter with the stored progress marker for this type. |
| + virtual void GetDownloadProgress( |
| + sync_pb::DataTypeProgressMarker* progress_marker) const = 0; |
| + |
| + // 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 handler's type, and the set of SyncEntities must include all |
| + // entities of this type found in the response message. |
| + virtual void ProcessGetUpdatesResponse( |
| + const sync_pb::DataTypeProgressMarker& progress_marker, |
| + const SyncEntityList& applicable_updates, |
|
tim (not reviewing)
2014/02/18 19:15:01
describe what "applicable" means in this context.
rlarocque
2014/02/18 20:01:13
Done.
|
| + sessions::StatusController* status) = 0; |
| + |
|
tim (not reviewing)
2014/02/18 19:15:01
nit - extra newline.
rlarocque
2014/02/18 20:01:13
Done.
|
| + |
| + // Called at the end of a non-configure GetUpdates loop to apply any unapplied |
| + // updates. |
| + virtual void ApplyUpdates(sessions::StatusController* status) = 0; |
| + |
| + // Called at the end of a configure GetUpdates loop to perform any required |
| + // post-initial-download update application. |
| + virtual void PassiveApplyUpdates(sessions::StatusController* status) = 0; |
| +}; |
| + |
| +} // namespace syncer |
| + |
| +#endif // SYNC_ENGINE_UPDATE_HANDLER_H_ |