| 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..eb1ee4de6381968d8a75a99befc464d462d97d97
|
| --- /dev/null
|
| +++ b/sync/engine/update_handler.h
|
| @@ -0,0 +1,63 @@
|
| +// 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, receive, and apply updates
|
| +// from the sync server.
|
| +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.
|
| + //
|
| + // In this context, "applicable_updates" means the set of updates belonging to
|
| + // this type.
|
| + virtual void ProcessGetUpdatesResponse(
|
| + const sync_pb::DataTypeProgressMarker& progress_marker,
|
| + const SyncEntityList& applicable_updates,
|
| + sessions::StatusController* status) = 0;
|
| +
|
| + // 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_
|
|
|