1 // Copyright 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_SYNCABLE_WRITE_TRANSACTION_H_
6 #define SYNC_SYNCABLE_SYNCABLE_WRITE_TRANSACTION_H_
8 #include "sync/base/sync_export.h"
9 #include "sync/syncable/entry_kernel.h"
10 #include "sync/syncable/syncable_base_transaction.h"
15 SYNC_EXPORT
extern const int64 kInvalidTransactionVersion
;
17 // Locks db in constructor, unlocks in destructor.
18 class SYNC_EXPORT WriteTransaction
: public BaseTransaction
{
20 WriteTransaction(const tracked_objects::Location
& from_here
,
21 WriterTag writer
, Directory
* directory
);
23 // Constructor used for getting back transaction version after making sync
24 // API changes to one model. If model is changed by the transaction,
25 // the new transaction version of the model and modified nodes will be saved
26 // in |transaction_version| upon destruction of the transaction. If model is
27 // not changed, |transaction_version| will be kInvalidTransactionVersion.
28 WriteTransaction(const tracked_objects::Location
& from_here
,
29 Directory
* directory
, int64
* transaction_version
);
31 virtual ~WriteTransaction();
33 void SaveOriginal(const EntryKernel
* entry
);
36 // Overridden by tests.
37 virtual void NotifyTransactionComplete(ModelTypeSet models_with_changes
);
40 friend class MutableEntry
;
42 // Clears |mutations_|.
43 ImmutableEntryKernelMutationMap
RecordMutations();
45 void UnlockAndNotify(const ImmutableEntryKernelMutationMap
& mutations
);
47 ModelTypeSet
NotifyTransactionChangingAndEnding(
48 const ImmutableEntryKernelMutationMap
& mutations
);
50 // Increment versions of the models whose entries are modified and set the
51 // version on the changed entries.
52 void UpdateTransactionVersion(const std::vector
<int64
>& entry_changed
);
54 // Only the original fields are filled in until |RecordMutations()|.
55 // We use a mutation map instead of a kernel set to avoid copying.
56 EntryKernelMutationMap mutations_
;
58 // Stores new transaction version of changed model and nodes if model is
59 // indeed changed. kInvalidTransactionVersion otherwise. Not owned.
60 int64
* transaction_version_
;
62 DISALLOW_COPY_AND_ASSIGN(WriteTransaction
);
65 } // namespace syncable
68 #endif // SYNC_SYNCABLE_SYNCABLE_WRITE_TRANSACTION_H_