| OLD | NEW | 
|---|
|  | (Empty) | 
| 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 |  | 
| 3 // found in the LICENSE file. |  | 
| 4 |  | 
| 5 #include "chrome/browser/sync/engine/resolve_conflicts_command.h" |  | 
| 6 |  | 
| 7 #include "chrome/browser/sync/engine/conflict_resolver.h" |  | 
| 8 #include "chrome/browser/sync/sessions/session_state.h" |  | 
| 9 #include "chrome/browser/sync/sessions/sync_session.h" |  | 
| 10 #include "chrome/browser/sync/syncable/syncable.h" |  | 
| 11 |  | 
| 12 namespace browser_sync { |  | 
| 13 |  | 
| 14 ResolveConflictsCommand::ResolveConflictsCommand() {} |  | 
| 15 ResolveConflictsCommand::~ResolveConflictsCommand() {} |  | 
| 16 |  | 
| 17 std::set<ModelSafeGroup> ResolveConflictsCommand::GetGroupsToChange( |  | 
| 18     const sessions::SyncSession& session) const { |  | 
| 19   return session.GetEnabledGroupsWithConflicts(); |  | 
| 20 } |  | 
| 21 |  | 
| 22 SyncerError ResolveConflictsCommand::ModelChangingExecuteImpl( |  | 
| 23     sessions::SyncSession* session) { |  | 
| 24   ConflictResolver* resolver = session->context()->resolver(); |  | 
| 25   DCHECK(resolver); |  | 
| 26 |  | 
| 27   syncable::Directory* dir = session->context()->directory(); |  | 
| 28   sessions::StatusController* status = session->mutable_status_controller(); |  | 
| 29   const sessions::ConflictProgress* progress = status->conflict_progress(); |  | 
| 30   if (!progress) |  | 
| 31     return SYNCER_OK;  // Nothing to do. |  | 
| 32   syncable::WriteTransaction trans(FROM_HERE, syncable::SYNCER, dir); |  | 
| 33   const Cryptographer* cryptographer = dir->GetCryptographer(&trans); |  | 
| 34   status->update_conflicts_resolved( |  | 
| 35       resolver->ResolveConflicts(&trans, cryptographer, *progress, status)); |  | 
| 36 |  | 
| 37   return SYNCER_OK; |  | 
| 38 } |  | 
| 39 |  | 
| 40 }  // namespace browser_sync |  | 
| OLD | NEW | 
|---|