OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef SYNC_SYNCABLE_SYNCABLE_BASE_TRANSACTION_H_ | 5 #ifndef SYNC_SYNCABLE_SYNCABLE_BASE_TRANSACTION_H_ |
6 #define SYNC_SYNCABLE_SYNCABLE_BASE_TRANSACTION_H_ | 6 #define SYNC_SYNCABLE_SYNCABLE_BASE_TRANSACTION_H_ |
7 | 7 |
8 #include "base/location.h" | 8 #include "base/location.h" |
| 9 #include "sync/base/sync_export.h" |
9 #include "sync/syncable/syncable_id.h" | 10 #include "sync/syncable/syncable_id.h" |
10 | 11 |
11 namespace syncer { | 12 namespace syncer { |
12 namespace syncable { | 13 namespace syncable { |
13 | 14 |
14 class Directory; | 15 class Directory; |
15 | 16 |
16 // A WriteTransaction has a writer tag describing which body of code is doing | 17 // A WriteTransaction has a writer tag describing which body of code is doing |
17 // the write. This is defined up here since WriteTransactionInfo also contains | 18 // the write. This is defined up here since WriteTransactionInfo also contains |
18 // one. | 19 // one. |
19 enum WriterTag { | 20 enum WriterTag { |
20 INVALID, | 21 INVALID, |
21 SYNCER, | 22 SYNCER, |
22 AUTHWATCHER, | 23 AUTHWATCHER, |
23 UNITTEST, | 24 UNITTEST, |
24 VACUUM_AFTER_SAVE, | 25 VACUUM_AFTER_SAVE, |
25 PURGE_ENTRIES, | 26 PURGE_ENTRIES, |
26 SYNCAPI | 27 SYNCAPI |
27 }; | 28 }; |
28 | 29 |
29 // Make sure to update this if you update WriterTag. | 30 // Make sure to update this if you update WriterTag. |
30 std::string WriterTagToString(WriterTag writer_tag); | 31 std::string WriterTagToString(WriterTag writer_tag); |
31 | 32 |
32 class BaseTransaction { | 33 class SYNC_EXPORT_PRIVATE BaseTransaction { |
33 public: | 34 public: |
34 inline Directory* directory() const { return directory_; } | 35 inline Directory* directory() const { return directory_; } |
35 inline Id root_id() const { return Id(); } | 36 inline Id root_id() const { return Id(); } |
36 | 37 |
37 virtual ~BaseTransaction(); | 38 virtual ~BaseTransaction(); |
38 | 39 |
39 // This should be called when a database corruption is detected and there is | 40 // This should be called when a database corruption is detected and there is |
40 // no way for us to recover short of wiping the database clean. When this is | 41 // no way for us to recover short of wiping the database clean. When this is |
41 // called we set a bool in the transaction. The caller has to unwind the | 42 // called we set a bool in the transaction. The caller has to unwind the |
42 // stack. When the destructor for the transaction is called it acts upon the | 43 // stack. When the destructor for the transaction is called it acts upon the |
(...skipping 30 matching lines...) Expand all Loading... |
73 | 74 |
74 private: | 75 private: |
75 friend class Entry; | 76 friend class Entry; |
76 DISALLOW_COPY_AND_ASSIGN(BaseTransaction); | 77 DISALLOW_COPY_AND_ASSIGN(BaseTransaction); |
77 }; | 78 }; |
78 | 79 |
79 } // namespace syncable | 80 } // namespace syncable |
80 } // namespace syncer | 81 } // namespace syncer |
81 | 82 |
82 #endif // SYNC_SYNCABLE_SYNCABLE_BASE_TRANSACTION_H_ | 83 #endif // SYNC_SYNCABLE_SYNCABLE_BASE_TRANSACTION_H_ |
OLD | NEW |