| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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 "sync/internal_api/all_status.h" | 5 #include "sync/engine/all_status.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/port.h" | 10 #include "base/port.h" |
| 11 #include "sync/engine/net/server_connection_manager.h" | 11 #include "sync/engine/net/server_connection_manager.h" |
| 12 #include "sync/internal_api/public/syncable/model_type.h" | 12 #include "sync/internal_api/public/syncable/model_type.h" |
| 13 #include "sync/sessions/session_state.h" | 13 #include "sync/sessions/session_state.h" |
| 14 | 14 |
| 15 namespace browser_sync { | 15 namespace browser_sync { |
| 16 | 16 |
| 17 AllStatus::AllStatus() { | 17 AllStatus::AllStatus() { |
| 18 status_.initial_sync_ended = true; | 18 status_.initial_sync_ended = true; |
| 19 status_.notifications_enabled = false; | 19 status_.notifications_enabled = false; |
| 20 status_.cryptographer_ready = false; | 20 status_.cryptographer_ready = false; |
| 21 status_.crypto_has_pending_keys = false; | 21 status_.crypto_has_pending_keys = false; |
| 22 } | 22 } |
| 23 | 23 |
| 24 AllStatus::~AllStatus() { | 24 AllStatus::~AllStatus() { |
| 25 } | 25 } |
| 26 | 26 |
| 27 sync_api::SyncManager::Status AllStatus::CreateBlankStatus() const { | 27 sync_api::SyncStatus AllStatus::CreateBlankStatus() const { |
| 28 // Status is initialized with the previous status value. Variables | 28 // Status is initialized with the previous status value. Variables |
| 29 // whose values accumulate (e.g. lifetime counters like updates_received) | 29 // whose values accumulate (e.g. lifetime counters like updates_received) |
| 30 // are not to be cleared here. | 30 // are not to be cleared here. |
| 31 sync_api::SyncManager::Status status = status_; | 31 sync_api::SyncStatus status = status_; |
| 32 status.encryption_conflicts = 0; | 32 status.encryption_conflicts = 0; |
| 33 status.hierarchy_conflicts = 0; | 33 status.hierarchy_conflicts = 0; |
| 34 status.simple_conflicts = 0; | 34 status.simple_conflicts = 0; |
| 35 status.server_conflicts = 0; | 35 status.server_conflicts = 0; |
| 36 status.committed_count = 0; | 36 status.committed_count = 0; |
| 37 status.initial_sync_ended = false; | 37 status.initial_sync_ended = false; |
| 38 status.updates_available = 0; | 38 status.updates_available = 0; |
| 39 return status; | 39 return status; |
| 40 } | 40 } |
| 41 | 41 |
| 42 sync_api::SyncManager::Status AllStatus::CalcSyncing( | 42 sync_api::SyncStatus AllStatus::CalcSyncing( |
| 43 const SyncEngineEvent &event) const { | 43 const SyncEngineEvent &event) const { |
| 44 sync_api::SyncManager::Status status = CreateBlankStatus(); | 44 sync_api::SyncStatus status = CreateBlankStatus(); |
| 45 const sessions::SyncSessionSnapshot& snapshot = event.snapshot; | 45 const sessions::SyncSessionSnapshot& snapshot = event.snapshot; |
| 46 status.encryption_conflicts = snapshot.num_encryption_conflicts(); | 46 status.encryption_conflicts = snapshot.num_encryption_conflicts(); |
| 47 status.hierarchy_conflicts = snapshot.num_hierarchy_conflicts(); | 47 status.hierarchy_conflicts = snapshot.num_hierarchy_conflicts(); |
| 48 status.simple_conflicts = snapshot.num_simple_conflicts(); | 48 status.simple_conflicts = snapshot.num_simple_conflicts(); |
| 49 status.server_conflicts = snapshot.num_server_conflicts(); | 49 status.server_conflicts = snapshot.num_server_conflicts(); |
| 50 status.committed_count = snapshot.syncer_status().num_successful_commits; | 50 status.committed_count = snapshot.syncer_status().num_successful_commits; |
| 51 | 51 |
| 52 if (event.what_happened == SyncEngineEvent::SYNC_CYCLE_BEGIN) { | 52 if (event.what_happened == SyncEngineEvent::SYNC_CYCLE_BEGIN) { |
| 53 status.syncing = true; | 53 status.syncing = true; |
| 54 } else if (event.what_happened == SyncEngineEvent::SYNC_CYCLE_ENDED) { | 54 } else if (event.what_happened == SyncEngineEvent::SYNC_CYCLE_ENDED) { |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 112 case SyncEngineEvent::ACTIONABLE_ERROR: | 112 case SyncEngineEvent::ACTIONABLE_ERROR: |
| 113 status_ = CreateBlankStatus(); | 113 status_ = CreateBlankStatus(); |
| 114 status_.sync_protocol_error = event.snapshot.errors().sync_protocol_error; | 114 status_.sync_protocol_error = event.snapshot.errors().sync_protocol_error; |
| 115 break; | 115 break; |
| 116 default: | 116 default: |
| 117 LOG(ERROR) << "Unrecognized Syncer Event: " << event.what_happened; | 117 LOG(ERROR) << "Unrecognized Syncer Event: " << event.what_happened; |
| 118 break; | 118 break; |
| 119 } | 119 } |
| 120 } | 120 } |
| 121 | 121 |
| 122 sync_api::SyncManager::Status AllStatus::status() const { | 122 sync_api::SyncStatus AllStatus::status() const { |
| 123 base::AutoLock lock(mutex_); | 123 base::AutoLock lock(mutex_); |
| 124 return status_; | 124 return status_; |
| 125 } | 125 } |
| 126 | 126 |
| 127 void AllStatus::SetNotificationsEnabled(bool notifications_enabled) { | 127 void AllStatus::SetNotificationsEnabled(bool notifications_enabled) { |
| 128 ScopedStatusLock lock(this); | 128 ScopedStatusLock lock(this); |
| 129 status_.notifications_enabled = notifications_enabled; | 129 status_.notifications_enabled = notifications_enabled; |
| 130 } | 130 } |
| 131 | 131 |
| 132 void AllStatus::IncrementNotificationsReceived() { | 132 void AllStatus::IncrementNotificationsReceived() { |
| 133 ScopedStatusLock lock(this); | 133 ScopedStatusLock lock(this); |
| 134 ++status_.notifications_received; | 134 ++status_.notifications_received; |
| 135 } | 135 } |
| 136 | 136 |
| 137 void AllStatus::SetEncryptedTypes(syncable::ModelTypeSet types) { | 137 void AllStatus::SetEncryptedTypes(syncable::ModelTypeSet types) { |
| 138 ScopedStatusLock lock(this); | 138 ScopedStatusLock lock(this); |
| 139 status_.encrypted_types = types; | 139 status_.encrypted_types = types; |
| 140 } | 140 } |
| 141 | 141 |
| 142 void AllStatus::SetThrottledTypes(const syncable::ModelTypeSet& types) { |
| 143 ScopedStatusLock lock(this); |
| 144 status_.throttled_types = types; |
| 145 } |
| 146 |
| 142 void AllStatus::SetCryptographerReady(bool ready) { | 147 void AllStatus::SetCryptographerReady(bool ready) { |
| 143 ScopedStatusLock lock(this); | 148 ScopedStatusLock lock(this); |
| 144 status_.cryptographer_ready = ready; | 149 status_.cryptographer_ready = ready; |
| 145 } | 150 } |
| 146 | 151 |
| 147 void AllStatus::SetCryptoHasPendingKeys(bool has_pending_keys) { | 152 void AllStatus::SetCryptoHasPendingKeys(bool has_pending_keys) { |
| 148 ScopedStatusLock lock(this); | 153 ScopedStatusLock lock(this); |
| 149 status_.crypto_has_pending_keys = has_pending_keys; | 154 status_.crypto_has_pending_keys = has_pending_keys; |
| 150 } | 155 } |
| 151 | 156 |
| 152 void AllStatus::SetUniqueId(const std::string& guid) { | 157 void AllStatus::SetUniqueId(const std::string& guid) { |
| 153 ScopedStatusLock lock(this); | 158 ScopedStatusLock lock(this); |
| 154 status_.unique_id = guid; | 159 status_.unique_id = guid; |
| 155 } | 160 } |
| 156 | 161 |
| 157 ScopedStatusLock::ScopedStatusLock(AllStatus* allstatus) | 162 ScopedStatusLock::ScopedStatusLock(AllStatus* allstatus) |
| 158 : allstatus_(allstatus) { | 163 : allstatus_(allstatus) { |
| 159 allstatus->mutex_.Acquire(); | 164 allstatus->mutex_.Acquire(); |
| 160 } | 165 } |
| 161 | 166 |
| 162 ScopedStatusLock::~ScopedStatusLock() { | 167 ScopedStatusLock::~ScopedStatusLock() { |
| 163 allstatus_->mutex_.Release(); | 168 allstatus_->mutex_.Release(); |
| 164 } | 169 } |
| 165 | 170 |
| 166 } // namespace browser_sync | 171 } // namespace browser_sync |
| OLD | NEW |