summaryrefslogtreecommitdiffstats
path: root/chrome/browser/sync/engine/resolve_conflicts_command.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/sync/engine/resolve_conflicts_command.cc')
-rw-r--r--chrome/browser/sync/engine/resolve_conflicts_command.cc28
1 files changed, 28 insertions, 0 deletions
diff --git a/chrome/browser/sync/engine/resolve_conflicts_command.cc b/chrome/browser/sync/engine/resolve_conflicts_command.cc
new file mode 100644
index 0000000..6caf9b4
--- /dev/null
+++ b/chrome/browser/sync/engine/resolve_conflicts_command.cc
@@ -0,0 +1,28 @@
+// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/sync/engine/resolve_conflicts_command.h"
+
+#include "chrome/browser/sync/engine/conflict_resolver.h"
+#include "chrome/browser/sync/engine/syncer_session.h"
+#include "chrome/browser/sync/syncable/directory_manager.h"
+
+namespace browser_sync {
+
+ResolveConflictsCommand::ResolveConflictsCommand() {}
+ResolveConflictsCommand::~ResolveConflictsCommand() {}
+
+void ResolveConflictsCommand::ModelChangingExecuteImpl(
+ SyncerSession* session) {
+ if (!session->resolver())
+ return;
+ syncable::ScopedDirLookup dir(session->dirman(), session->account_name());
+ if (!dir.good())
+ return;
+ ConflictResolutionView conflict_view(session);
+ session->set_conflicts_resolved(
+ session->resolver()->ResolveConflicts(dir, &conflict_view, session));
+}
+
+} // namespace browser_sync