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

Side by Side Diff: chrome/browser/sync/glue/syncable_service_adapter.cc

Issue 7453014: [Sync] Refactor sync datatype error handling. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Really fix compile Created 9 years, 5 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) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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/glue/syncable_service_adapter.h" 5 #include "chrome/browser/sync/glue/syncable_service_adapter.h"
6 6
7 #include "chrome/browser/sync/api/sync_error.h"
7 #include "chrome/browser/sync/api/syncable_service.h" 8 #include "chrome/browser/sync/api/syncable_service.h"
8 #include "chrome/browser/sync/api/sync_data.h" 9 #include "chrome/browser/sync/api/sync_data.h"
9 #include "chrome/browser/sync/glue/generic_change_processor.h" 10 #include "chrome/browser/sync/glue/generic_change_processor.h"
10 11
11 namespace browser_sync { 12 namespace browser_sync {
12 13
13 SyncableServiceAdapter::SyncableServiceAdapter( 14 SyncableServiceAdapter::SyncableServiceAdapter(
14 syncable::ModelType type, 15 syncable::ModelType type,
15 SyncableService* service, 16 SyncableService* service,
16 GenericChangeProcessor* sync_processor) 17 GenericChangeProcessor* sync_processor)
17 : syncing_(false), 18 : syncing_(false),
18 type_(type), 19 type_(type),
19 service_(service), 20 service_(service),
20 sync_processor_(sync_processor) { 21 sync_processor_(sync_processor) {
21 } 22 }
22 23
23 SyncableServiceAdapter::~SyncableServiceAdapter() { 24 SyncableServiceAdapter::~SyncableServiceAdapter() {
24 if (syncing_) { 25 if (syncing_) {
25 NOTREACHED(); 26 NOTREACHED();
26 LOG(ERROR) << "SyncableServiceAdapter for " 27 LOG(ERROR) << "SyncableServiceAdapter for "
27 << syncable::ModelTypeToString(type_) << " destroyed before " 28 << syncable::ModelTypeToString(type_) << " destroyed before "
28 << "without being shut down properly."; 29 << "without being shut down properly.";
29 service_->StopSyncing(type_); 30 service_->StopSyncing(type_);
30 } 31 }
31 } 32 }
32 33
33 bool SyncableServiceAdapter::AssociateModels() { 34 bool SyncableServiceAdapter::AssociateModels(SyncError* error) {
34 syncing_ = true; 35 syncing_ = true;
35 SyncDataList initial_sync_data; 36 SyncDataList initial_sync_data;
36 if (!sync_processor_->GetSyncDataForType(type_, &initial_sync_data)) { 37 if (!sync_processor_->GetSyncDataForType(type_,
38 &initial_sync_data,
39 error)) {
37 return false; 40 return false;
38 } 41 }
42 DCHECK(!error->IsInitialized());
39 return service_->MergeDataAndStartSyncing(type_, 43 return service_->MergeDataAndStartSyncing(type_,
40 initial_sync_data, 44 initial_sync_data,
41 sync_processor_); 45 sync_processor_,
46 error);
42 } 47 }
43 48
44 bool SyncableServiceAdapter::DisassociateModels() { 49 bool SyncableServiceAdapter::DisassociateModels(SyncError* error) {
45 service_->StopSyncing(type_); 50 service_->StopSyncing(type_);
46 syncing_ = false; 51 syncing_ = false;
47 return true; 52 return true;
48 } 53 }
49 54
50 bool SyncableServiceAdapter::SyncModelHasUserCreatedNodes(bool* has_nodes) { 55 bool SyncableServiceAdapter::SyncModelHasUserCreatedNodes(bool* has_nodes) {
51 return sync_processor_->SyncModelHasUserCreatedNodes(type_, has_nodes); 56 return sync_processor_->SyncModelHasUserCreatedNodes(type_, has_nodes);
52 } 57 }
53 58
54 void SyncableServiceAdapter::AbortAssociation() { 59 void SyncableServiceAdapter::AbortAssociation() {
55 service_->StopSyncing(type_); 60 service_->StopSyncing(type_);
56 syncing_ = false; 61 syncing_ = false;
57 } 62 }
58 63
59 bool SyncableServiceAdapter::CryptoReadyIfNecessary() { 64 bool SyncableServiceAdapter::CryptoReadyIfNecessary() {
60 return sync_processor_->CryptoReadyIfNecessary(type_); 65 return sync_processor_->CryptoReadyIfNecessary(type_);
61 } 66 }
62 67
63 } // namespace browser_sync 68 } // namespace browser_sync
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698