| Index: chrome/browser/sync/engine/model_changing_syncer_command.cc
|
| diff --git a/chrome/browser/sync/engine/model_changing_syncer_command.cc b/chrome/browser/sync/engine/model_changing_syncer_command.cc
|
| index 1c392cbd20877ecfc27fa47abddc076dd2627361..cd99da9150315dffe7f5990731d80f156884b902 100644
|
| --- a/chrome/browser/sync/engine/model_changing_syncer_command.cc
|
| +++ b/chrome/browser/sync/engine/model_changing_syncer_command.cc
|
| @@ -1,4 +1,4 @@
|
| -// Copyright (c) 2011 The Chromium Authors. All rights reserved.
|
| +// Copyright (c) 2012 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.
|
|
|
| @@ -9,15 +9,16 @@
|
| #include "base/bind_helpers.h"
|
| #include "chrome/browser/sync/sessions/status_controller.h"
|
| #include "chrome/browser/sync/sessions/sync_session.h"
|
| -#include "chrome/browser/sync/util/unrecoverable_error_info.h"
|
|
|
| namespace browser_sync {
|
|
|
| -void ModelChangingSyncerCommand::ExecuteImpl(sessions::SyncSession* session) {
|
| +SyncerError ModelChangingSyncerCommand::ExecuteImpl(
|
| + sessions::SyncSession* session) {
|
| work_session_ = session;
|
| - if (!ModelNeutralExecuteImpl(work_session_)) {
|
| - return;
|
| - }
|
| + SyncerError result = ModelNeutralExecuteImpl(work_session_);
|
| +
|
| + if (result != SYNCER_OK)
|
| + return result;
|
|
|
| const std::set<ModelSafeGroup>& groups_to_change =
|
| GetGroupsToChange(*work_session_);
|
| @@ -40,15 +41,19 @@ void ModelChangingSyncerCommand::ExecuteImpl(sessions::SyncSession* session) {
|
| // unretained.
|
| base::Unretained(this));
|
|
|
| - // TODO(lipalani): Check the return value for an unrecoverable error.
|
| - ignore_result(worker->DoWorkAndWaitUntilDone(c));
|
| -
|
| + SyncerError this_worker_result = worker->DoWorkAndWaitUntilDone(c);
|
| + // TODO(rlarocque): Figure out a better way to deal with errors from
|
| + // multiple models at once. See also: crbug.com/109422.
|
| + if (this_worker_result != SYNCER_OK)
|
| + result = this_worker_result;
|
| }
|
| +
|
| + return result;
|
| }
|
|
|
| -bool ModelChangingSyncerCommand::ModelNeutralExecuteImpl(
|
| +SyncerError ModelChangingSyncerCommand::ModelNeutralExecuteImpl(
|
| sessions::SyncSession* session) {
|
| - return true;
|
| + return SYNCER_OK;
|
| }
|
|
|
| } // namespace browser_sync
|
|
|