1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef SYNC_SYNCABLE_DIRECTORY_CHANGE_DELEGATE_H_
6 #define SYNC_SYNCABLE_DIRECTORY_CHANGE_DELEGATE_H_
8 #include "sync/internal_api/public/base/model_type.h"
9 #include "sync/syncable/write_transaction_info.h"
14 // This is an interface for listening to directory change events, triggered by
15 // the releasing of the syncable transaction. The delegate performs work to
16 // 1. Calculate changes, depending on the source of the transaction
17 // (HandleCalculateChangesChangeEventFromSyncer/Syncapi).
18 // 2. Perform final work while the transaction is held
19 // (HandleTransactionEndingChangeEvent).
20 // 3. Perform any work that should be done after the transaction is released.
21 // (HandleTransactionCompleteChangeEvent).
23 // Note that these methods may be called on *any* thread.
24 class DirectoryChangeDelegate
{
26 virtual void HandleCalculateChangesChangeEventFromSyncApi(
27 const ImmutableWriteTransactionInfo
& write_transaction_info
,
28 BaseTransaction
* trans
) = 0;
29 virtual void HandleCalculateChangesChangeEventFromSyncer(
30 const ImmutableWriteTransactionInfo
& write_transaction_info
,
31 BaseTransaction
* trans
) = 0;
32 // Must return the set of all ModelTypes that were modified in the
34 virtual ModelTypeSet
HandleTransactionEndingChangeEvent(
35 const ImmutableWriteTransactionInfo
& write_transaction_info
,
36 BaseTransaction
* trans
) = 0;
37 virtual void HandleTransactionCompleteChangeEvent(
38 ModelTypeSet models_with_changes
) = 0;
40 virtual ~DirectoryChangeDelegate() {}
43 } // namespace syncable
46 #endif // SYNC_SYNCABLE_DIRECTORY_CHANGE_DELEGATE_H_