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

Side by Side Diff: chrome/browser/sync/engine/build_and_process_conflict_sets_command.cc

Issue 211019: Fix compiling of sync on linux. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 11 years, 3 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2006-2009 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 #include "chrome/browser/sync/engine/build_and_process_conflict_sets_command.h" 5 #include "chrome/browser/sync/engine/build_and_process_conflict_sets_command.h"
6 6
7 #include <string> 7 #include <string>
8 #include <sstream> 8 #include <sstream>
9 #include <vector> 9 #include <vector>
10 10
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
53 syncable::WriteTransaction* trans, SyncerSession* const session) { 53 syncable::WriteTransaction* trans, SyncerSession* const session) {
54 bool rv = false; 54 bool rv = false;
55 ConflictResolutionView conflict_view(session); 55 ConflictResolutionView conflict_view(session);
56 set<ConflictSet*>::const_iterator all_sets_iterator; 56 set<ConflictSet*>::const_iterator all_sets_iterator;
57 for(all_sets_iterator = conflict_view.ConflictSetsBegin(); 57 for(all_sets_iterator = conflict_view.ConflictSetsBegin();
58 all_sets_iterator != conflict_view.ConflictSetsEnd() ; ) { 58 all_sets_iterator != conflict_view.ConflictSetsEnd() ; ) {
59 const ConflictSet* conflict_set = *all_sets_iterator; 59 const ConflictSet* conflict_set = *all_sets_iterator;
60 CHECK(conflict_set->size() >= 2); 60 CHECK(conflict_set->size() >= 2);
61 // We scan the set to see if it consists of changes of only one type. 61 // We scan the set to see if it consists of changes of only one type.
62 ConflictSet::const_iterator i; 62 ConflictSet::const_iterator i;
63 int unsynced_count = 0, unapplied_count = 0; 63 size_t unsynced_count = 0, unapplied_count = 0;
64 for (i = conflict_set->begin(); i != conflict_set->end(); ++i) { 64 for (i = conflict_set->begin(); i != conflict_set->end(); ++i) {
65 syncable::Entry entry(trans, syncable::GET_BY_ID, *i); 65 syncable::Entry entry(trans, syncable::GET_BY_ID, *i);
66 CHECK(entry.good()); 66 CHECK(entry.good());
67 if (entry.Get(syncable::IS_UNSYNCED)) 67 if (entry.Get(syncable::IS_UNSYNCED))
68 unsynced_count++; 68 unsynced_count++;
69 if (entry.Get(syncable::IS_UNAPPLIED_UPDATE)) 69 if (entry.Get(syncable::IS_UNAPPLIED_UPDATE))
70 unapplied_count++; 70 unapplied_count++;
71 } 71 }
72 if (conflict_set->size() == unsynced_count && 0 == unapplied_count) { 72 if (conflict_set->size() == unsynced_count && 0 == unapplied_count) {
73 LOG(INFO) << "Skipped transactional commit attempt."; 73 LOG(INFO) << "Skipped transactional commit attempt.";
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
113 113
114 private: 114 private:
115 string name_stem_; 115 string name_stem_;
116 }; 116 };
117 117
118 bool RollbackEntry(syncable::WriteTransaction* trans, 118 bool RollbackEntry(syncable::WriteTransaction* trans,
119 syncable::EntryKernel* backup) { 119 syncable::EntryKernel* backup) {
120 syncable::MutableEntry entry(trans, syncable::GET_BY_HANDLE, 120 syncable::MutableEntry entry(trans, syncable::GET_BY_HANDLE,
121 backup->ref(syncable::META_HANDLE)); 121 backup->ref(syncable::META_HANDLE));
122 CHECK(entry.good()); 122 CHECK(entry.good());
123 bool was_del = entry.Get(syncable::IS_DEL);
124 123
125 if (!entry.Put(syncable::IS_DEL, backup->ref(syncable::IS_DEL))) 124 if (!entry.Put(syncable::IS_DEL, backup->ref(syncable::IS_DEL)))
126 return false; 125 return false;
127 syncable::Name name = syncable::Name::FromEntryKernel(backup); 126 syncable::Name name = syncable::Name::FromEntryKernel(backup);
128 if (!entry.PutParentIdAndName(backup->ref(syncable::PARENT_ID), name)) 127 if (!entry.PutParentIdAndName(backup->ref(syncable::PARENT_ID), name))
129 return false; 128 return false;
130 129
131 if (!backup->ref(syncable::IS_DEL)) { 130 if (!backup->ref(syncable::IS_DEL)) {
132 if (!entry.PutPredecessor(backup->ref(syncable::PREV_ID))) 131 if (!entry.PutPredecessor(backup->ref(syncable::PREV_ID)))
133 return false; 132 return false;
(...skipping 299 matching lines...) Expand 10 before | Expand all | Expand 10 after
433 return; 432 return;
434 LocallyDeletedPathChecker checker; 433 LocallyDeletedPathChecker checker;
435 if (!checker.CausingConflict(parent, *entry)) 434 if (!checker.CausingConflict(parent, *entry))
436 return; 435 return;
437 view->MergeSets(entry->Get(syncable::ID), parent.Get(syncable::ID)); 436 view->MergeSets(entry->Get(syncable::ID), parent.Get(syncable::ID));
438 CrawlDeletedTreeMergingSets(trans, parent, view, checker); 437 CrawlDeletedTreeMergingSets(trans, parent, view, checker);
439 } 438 }
440 } 439 }
441 440
442 } // namespace browser_sync 441 } // namespace browser_sync
OLDNEW
« no previous file with comments | « chrome/browser/sync/engine/build_and_process_conflict_sets_command.h ('k') | chrome/browser/sync/engine/conflict_resolver.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698