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

Side by Side Diff: sync/internal_api/all_status.cc

Issue 10454105: sync: Refactor per-datatype throttling (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Minor fixes Created 8 years, 6 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) 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/internal_api/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"
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698