| // 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. |
| |
| #ifndef SYNC_ENGINE_STORE_TIMESTAMPS_COMMAND_H_ |
| #define SYNC_ENGINE_STORE_TIMESTAMPS_COMMAND_H_ |
| |
| #include "base/compiler_specific.h" |
| #include "sync/base/sync_export.h" |
| #include "sync/engine/syncer_command.h" |
| #include "sync/engine/syncer_types.h" |
| #include "sync/internal_api/public/base/model_type.h" |
| |
| namespace sync_pb { |
| class GetUpdatesResponse; |
| } // namespace sync_pb |
| |
| namespace syncer { |
| |
| namespace syncable { |
| class Directory; |
| } // namespace syncable |
| |
| // Sets |dir|'s progress markers from the data in |response|. Returns |
| // the set of model types with new progress markers. |
| SYNC_EXPORT_PRIVATE ModelTypeSet ProcessNewProgressMarkers( |
| const sync_pb::GetUpdatesResponse& response, |
| syncable::Directory* dir); |
| |
| // A syncer command that extracts the changelog timestamp information from |
| // a GetUpdatesResponse (fetched in DownloadUpdatesCommand) and stores |
| // it in the directory. This is meant to run immediately after |
| // ProcessUpdatesCommand. |
| // |
| // Preconditions - all updates in the SyncerSesssion have been stored in the |
| // database, meaning it is safe to update the persisted |
| // timestamps. |
| // |
| // Postconditions - The next_timestamp returned by the server will be |
| // saved into the directory (where it will be used |
| // the next time that DownloadUpdatesCommand runs). |
| class StoreTimestampsCommand : public SyncerCommand { |
| public: |
| StoreTimestampsCommand(); |
| virtual ~StoreTimestampsCommand(); |
| |
| // SyncerCommand implementation. |
| virtual SyncerError ExecuteImpl(sessions::SyncSession* session) OVERRIDE; |
| |
| private: |
| DISALLOW_COPY_AND_ASSIGN(StoreTimestampsCommand); |
| }; |
| |
| } // namespace syncer |
| |
| #endif // SYNC_ENGINE_STORE_TIMESTAMPS_COMMAND_H_ |