| Index: sync/engine/updater_list.h
|
| diff --git a/sync/engine/updater_list.h b/sync/engine/updater_list.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..7c661569c31a5a6236b11fd8bb095bf24b6c4266
|
| --- /dev/null
|
| +++ b/sync/engine/updater_list.h
|
| @@ -0,0 +1,85 @@
|
| +// 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_UPDATER_LIST_H_
|
| +#define SYNC_ENGINE_UPDATER_LIST_H_
|
| +
|
| +#include <map>
|
| +#include <vector>
|
| +
|
| +#include "base/stl_util.h"
|
| +#include "sync/base/sync_export.h"
|
| +#include "sync/internal_api/public/base/model_type.h"
|
| +#include "sync/internal_api/public/engine/model_safe_worker.h"
|
| +
|
| +namespace sync_pb {
|
| +class GetUpdatesMessage;
|
| +class GetUpdatesResponse;
|
| +} // namespace sync_pb
|
| +
|
| +namespace syncer {
|
| +
|
| +namespace sessions {
|
| +class StatusController;
|
| +} // namespace sessions
|
| +
|
| +namespace syncable {
|
| +class Directory;
|
| +} // namespace syncable
|
| +
|
| +class SyncDirectoryUpdateHandler;
|
| +
|
| +typedef std::vector<const sync_pb::SyncEntity*> SyncEntityList;
|
| +typedef std::map<ModelType, SyncEntityList> TypeSyncEntityMap;
|
| +
|
| +// This class manages the set of per-type syncer objects.
|
| +//
|
| +// It owns these types and hides the details of iterating over all of them.
|
| +// Most methods allow the caller to specify a subset of types on which the
|
| +// operation is to be applied. It is a logic error if the supplied set of types
|
| +// contains a type which was not previously registered with the manager.
|
| +class SYNC_EXPORT_PRIVATE UpdaterList {
|
| + public:
|
| + UpdaterList();
|
| + ~UpdaterList();
|
| +
|
| + // Builds or rebuilds the set of syncable::Directory sync type objects.
|
| + void SetEnabledSyncDirectoryTypes(
|
| + const std::vector<scoped_refptr<ModelSafeWorker> > workers,
|
| + const ModelSafeRoutingInfo& routing_info,
|
| + syncable::Directory* dir);
|
| +
|
| + // Populates a GetUpdates request message with per-type information.
|
| + void PrepareGetUpdates(ModelTypeSet gu_types,
|
| + sync_pb::GetUpdatesMessage* get_updates);
|
| +
|
| + // Processes a GetUpdates responses for each type.
|
| + bool ProcessGetUpdatesResponse(
|
| + ModelTypeSet gu_types,
|
| + const sync_pb::GetUpdatesResponse& gu_response,
|
| + sessions::StatusController* status_controller);
|
| +
|
| + // Applies pending updates for all sync types known to the manager.
|
| + void ApplyUpdatesForAllTypes(sessions::StatusController* status_controller);
|
| +
|
| + // Registers an update handler directly. Useful in tests.
|
| + void RegisterTypeForTest(
|
| + ModelType type,
|
| + SyncDirectoryUpdateHandler* handler);
|
| +
|
| + private:
|
| + typedef std::map<ModelType, SyncDirectoryUpdateHandler*> UpdateHandlerMap;
|
| +
|
| + // A map of 'update handlers', one for each enabled type.
|
| + // This must be kept in sync with the routing info. Our temporary solution to
|
| + // that problem is to initialize this map in set_routing_info().
|
| + UpdateHandlerMap update_handler_map_;
|
| +
|
| + // Deleter for the |update_handler_map_|.
|
| + STLValueDeleter<UpdateHandlerMap> update_handler_deleter_;
|
| +};
|
| +
|
| +} // namespace syncer
|
| +
|
| +#endif // SYNC_ENGINE_UPDATER_LIST_H_
|
|
|