Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(898)

Side by Side Diff: components/sync/engine_impl/conflict_resolver.h

Issue 2130453004: [Sync] Move //sync to //components/sync. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase. Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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 // A class that watches the syncer and attempts to resolve any conflicts that 5 // A class that watches the syncer and attempts to resolve any conflicts that
6 // occur. 6 // occur.
7 7
8 #ifndef SYNC_ENGINE_CONFLICT_RESOLVER_H_ 8 #ifndef COMPONENTS_SYNC_ENGINE_IMPL_CONFLICT_RESOLVER_H_
9 #define SYNC_ENGINE_CONFLICT_RESOLVER_H_ 9 #define COMPONENTS_SYNC_ENGINE_IMPL_CONFLICT_RESOLVER_H_
10 10
11 #include <set> 11 #include <set>
12 12
13 #include "base/gtest_prod_util.h" 13 #include "base/gtest_prod_util.h"
14 #include "base/macros.h" 14 #include "base/macros.h"
15 #include "sync/engine/syncer_types.h" 15 #include "components/sync/engine_impl/syncer_types.h"
16 16
17 namespace syncer { 17 namespace syncer {
18 18
19 namespace syncable { 19 namespace syncable {
20 class Id; 20 class Id;
21 class WriteTransaction; 21 class WriteTransaction;
22 } // namespace syncable 22 } // namespace syncable
23 23
24 class Cryptographer; 24 class Cryptographer;
25 struct UpdateCounters; 25 struct UpdateCounters;
26 26
27 namespace sessions { 27 namespace sessions {
28 class StatusController; 28 class StatusController;
29 } // namespace sessions 29 } // namespace sessions
30 30
31 class ConflictResolver { 31 class ConflictResolver {
32 public: 32 public:
33 // Enumeration of different conflict resolutions. Used for histogramming. 33 // Enumeration of different conflict resolutions. Used for histogramming.
34 enum SimpleConflictResolutions { 34 enum SimpleConflictResolutions {
35 OVERWRITE_LOCAL, // Resolved by overwriting local changes. 35 OVERWRITE_LOCAL, // Resolved by overwriting local changes.
36 OVERWRITE_SERVER, // Resolved by overwriting server changes. 36 OVERWRITE_SERVER, // Resolved by overwriting server changes.
37 UNDELETE, // Resolved by undeleting local item. 37 UNDELETE, // Resolved by undeleting local item.
38 IGNORE_ENCRYPTION, // Resolved by ignoring an encryption-only server 38 IGNORE_ENCRYPTION, // Resolved by ignoring an encryption-only server
39 // change. 39 // change.
40 NIGORI_MERGE, // Resolved by merging nigori nodes. 40 NIGORI_MERGE, // Resolved by merging nigori nodes.
41 CHANGES_MATCH, // Resolved by ignoring both local and server 41 CHANGES_MATCH, // Resolved by ignoring both local and server
42 // changes because they matched. 42 // changes because they matched.
43 CONFLICT_RESOLUTION_SIZE, 43 CONFLICT_RESOLUTION_SIZE,
44 }; 44 };
45 45
46 ConflictResolver(); 46 ConflictResolver();
47 ~ConflictResolver(); 47 ~ConflictResolver();
48 // Called by the syncer at the end of a update/commit cycle. 48 // Called by the syncer at the end of a update/commit cycle.
49 // Returns true if the syncer should try to apply its updates again. 49 // Returns true if the syncer should try to apply its updates again.
50 void ResolveConflicts(syncable::WriteTransaction* trans, 50 void ResolveConflicts(syncable::WriteTransaction* trans,
51 const Cryptographer* cryptographer, 51 const Cryptographer* cryptographer,
52 const std::set<syncable::Id>& simple_conflict_ids, 52 const std::set<syncable::Id>& simple_conflict_ids,
53 sessions::StatusController* status, 53 sessions::StatusController* status,
54 UpdateCounters* counters); 54 UpdateCounters* counters);
55 55
56 private: 56 private:
57 friend class SyncerTest; 57 friend class SyncerTest;
58 FRIEND_TEST_ALL_PREFIXES(SyncerTest, 58 FRIEND_TEST_ALL_PREFIXES(SyncerTest,
59 ConflictResolverMergeOverwritesLocalEntry); 59 ConflictResolverMergeOverwritesLocalEntry);
60 60
61 void ProcessSimpleConflict( 61 void ProcessSimpleConflict(syncable::WriteTransaction* trans,
62 syncable::WriteTransaction* trans, 62 const syncable::Id& id,
63 const syncable::Id& id, 63 const Cryptographer* cryptographer,
64 const Cryptographer* cryptographer, 64 sessions::StatusController* status,
65 sessions::StatusController* status, 65 UpdateCounters* counters);
66 UpdateCounters* counters);
67 66
68 DISALLOW_COPY_AND_ASSIGN(ConflictResolver); 67 DISALLOW_COPY_AND_ASSIGN(ConflictResolver);
69 }; 68 };
70 69
71 } // namespace syncer 70 } // namespace syncer
72 71
73 #endif // SYNC_ENGINE_CONFLICT_RESOLVER_H_ 72 #endif // COMPONENTS_SYNC_ENGINE_IMPL_CONFLICT_RESOLVER_H_
OLDNEW
« no previous file with comments | « components/sync/engine_impl/commit_util.cc ('k') | components/sync/engine_impl/conflict_resolver.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698