Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / sync / internal_api / public / write_transaction.h
blob8d8d101b67baf3391c18ed038acbb929d74f97a9
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_INTERNAL_API_PUBLIC_WRITE_TRANSACTION_H_
6 #define SYNC_INTERNAL_API_PUBLIC_WRITE_TRANSACTION_H_
8 #include "base/basictypes.h"
9 #include "base/compiler_specific.h"
10 #include "sync/api/sync_change_processor.h"
11 #include "sync/base/sync_export.h"
12 #include "sync/internal_api/public/base_transaction.h"
14 namespace tracked_objects {
15 class Location;
16 } // namespace tracked_objects
18 namespace syncer {
20 namespace syncable {
21 class BaseTransaction;
22 class WriteTransaction;
23 } // namespace syncable
25 // Sync API's WriteTransaction is a read/write BaseTransaction. It wraps
26 // a syncable::WriteTransaction.
28 // NOTE: Only a single model type can be mutated for a given
29 // WriteTransaction.
30 class SYNC_EXPORT WriteTransaction : public BaseTransaction {
31 public:
32 // Start a new read/write transaction.
33 WriteTransaction(const tracked_objects::Location& from_here,
34 UserShare* share);
35 // |transaction_version| stores updated model and nodes version if model
36 // is changed by the transaction, or syncer::syncable::kInvalidTransaction
37 // if not after transaction is closed. This constructor is used for model
38 // types that support embassy data.
39 WriteTransaction(const tracked_objects::Location& from_here,
40 UserShare* share, int64* transaction_version);
41 ~WriteTransaction() override;
43 // Provide access to the syncable transaction from the API WriteNode.
44 syncable::BaseTransaction* GetWrappedTrans() const override;
45 syncable::WriteTransaction* GetWrappedWriteTrans() { return transaction_; }
47 // Set's a |type|'s local context. |refresh_status| controls whether
48 // a datatype refresh is performed (clearing the progress marker token and
49 // setting the version of all synced entities to 1).
50 void SetDataTypeContext(
51 ModelType type,
52 syncer::SyncChangeProcessor::ContextRefreshStatus refresh_status,
53 const std::string& context);
55 // Update all entries that refer to |attachment_id| indicating that
56 // |attachment_id| has been uploaded to the sync server.
57 void UpdateEntriesMarkAttachmentAsOnServer(const AttachmentId& attachment_id);
59 protected:
60 WriteTransaction() {}
62 void SetTransaction(syncable::WriteTransaction* trans) {
63 transaction_ = trans;
66 private:
67 void* operator new(size_t size); // Transaction is meant for stack use only.
69 // The underlying syncable object which this class wraps.
70 syncable::WriteTransaction* transaction_;
72 DISALLOW_COPY_AND_ASSIGN(WriteTransaction);
75 } // namespace syncer
77 #endif // SYNC_INTERNAL_API_PUBLIC_WRITE_TRANSACTION_H_