| 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/sessions/sync_session.h" | 5 #include "sync/sessions/sync_session.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <iterator> | 8 #include <iterator> |
| 9 | 9 |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 30 matching lines...) Expand all Loading... |
| 41 } | 41 } |
| 42 // All enabled groups should have a corresponding worker. | 42 // All enabled groups should have a corresponding worker. |
| 43 DCHECK(std::includes( | 43 DCHECK(std::includes( |
| 44 groups_with_workers.begin(), groups_with_workers.end(), | 44 groups_with_workers.begin(), groups_with_workers.end(), |
| 45 enabled_groups.begin(), enabled_groups.end())); | 45 enabled_groups.begin(), enabled_groups.end())); |
| 46 } | 46 } |
| 47 } | 47 } |
| 48 return enabled_groups; | 48 return enabled_groups; |
| 49 } | 49 } |
| 50 | 50 |
| 51 void PurgeStalePayload(ModelTypePayloadMap* original, | 51 void PurgeStaleStates(ModelTypeStateMap* original, |
| 52 const ModelSafeRoutingInfo& routing_info) { | 52 const ModelSafeRoutingInfo& routing_info) { |
| 53 std::vector<ModelTypePayloadMap::iterator> iterators_to_delete; | 53 std::vector<ModelTypeStateMap::iterator> iterators_to_delete; |
| 54 for (ModelTypePayloadMap::iterator i = original->begin(); | 54 for (ModelTypeStateMap::iterator i = original->begin(); |
| 55 i != original->end(); ++i) { | 55 i != original->end(); ++i) { |
| 56 if (routing_info.end() == routing_info.find(i->first)) { | 56 if (routing_info.end() == routing_info.find(i->first)) { |
| 57 iterators_to_delete.push_back(i); | 57 iterators_to_delete.push_back(i); |
| 58 } | 58 } |
| 59 } | 59 } |
| 60 | 60 |
| 61 for (std::vector<ModelTypePayloadMap::iterator>::iterator | 61 for (std::vector<ModelTypeStateMap::iterator>::iterator |
| 62 it = iterators_to_delete.begin(); it != iterators_to_delete.end(); | 62 it = iterators_to_delete.begin(); it != iterators_to_delete.end(); |
| 63 ++it) { | 63 ++it) { |
| 64 original->erase(*it); | 64 original->erase(*it); |
| 65 } | 65 } |
| 66 } | 66 } |
| 67 | 67 |
| 68 } // namesepace | 68 } // namesepace |
| 69 | 69 |
| 70 SyncSession::SyncSession(SyncSessionContext* context, Delegate* delegate, | 70 SyncSession::SyncSession(SyncSessionContext* context, Delegate* delegate, |
| 71 const SyncSourceInfo& source, | 71 const SyncSourceInfo& source, |
| (...skipping 13 matching lines...) Expand all Loading... |
| 85 | 85 |
| 86 SyncSession::~SyncSession() {} | 86 SyncSession::~SyncSession() {} |
| 87 | 87 |
| 88 void SyncSession::Coalesce(const SyncSession& session) { | 88 void SyncSession::Coalesce(const SyncSession& session) { |
| 89 if (context_ != session.context() || delegate_ != session.delegate_) { | 89 if (context_ != session.context() || delegate_ != session.delegate_) { |
| 90 NOTREACHED(); | 90 NOTREACHED(); |
| 91 return; | 91 return; |
| 92 } | 92 } |
| 93 | 93 |
| 94 // When we coalesce sessions, the sync update source gets overwritten with the | 94 // When we coalesce sessions, the sync update source gets overwritten with the |
| 95 // most recent, while the type/payload map gets merged. | 95 // most recent, while the type/state map gets merged. |
| 96 CoalescePayloads(&source_.types, session.source_.types); | 96 CoalesceStates(&source_.types, session.source_.types); |
| 97 source_.updates_source = session.source_.updates_source; | 97 source_.updates_source = session.source_.updates_source; |
| 98 | 98 |
| 99 std::vector<ModelSafeWorker*> temp; | 99 std::vector<ModelSafeWorker*> temp; |
| 100 std::set_union(workers_.begin(), workers_.end(), | 100 std::set_union(workers_.begin(), workers_.end(), |
| 101 session.workers_.begin(), session.workers_.end(), | 101 session.workers_.begin(), session.workers_.end(), |
| 102 std::back_inserter(temp)); | 102 std::back_inserter(temp)); |
| 103 workers_.swap(temp); | 103 workers_.swap(temp); |
| 104 | 104 |
| 105 // We have to update the model safe routing info to the union. In case the | 105 // We have to update the model safe routing info to the union. In case the |
| 106 // same key is present in both pick the one from session. | 106 // same key is present in both pick the one from session. |
| (...skipping 18 matching lines...) Expand all Loading... |
| 125 ++it) { | 125 ++it) { |
| 126 if (routing_info_.find(it->first) != routing_info_.end()) { | 126 if (routing_info_.find(it->first) != routing_info_.end()) { |
| 127 temp_routing_info[it->first] = it->second; | 127 temp_routing_info[it->first] = it->second; |
| 128 } | 128 } |
| 129 } | 129 } |
| 130 | 130 |
| 131 // Now swap it. | 131 // Now swap it. |
| 132 routing_info_.swap(temp_routing_info); | 132 routing_info_.swap(temp_routing_info); |
| 133 | 133 |
| 134 // Now update the payload map. | 134 // Now update the payload map. |
| 135 PurgeStalePayload(&source_.types, session.routing_info_); | 135 PurgeStaleStates(&source_.types, session.routing_info_); |
| 136 | 136 |
| 137 // Now update the workers. | 137 // Now update the workers. |
| 138 std::vector<ModelSafeWorker*> temp; | 138 std::vector<ModelSafeWorker*> temp; |
| 139 std::set_intersection(workers_.begin(), workers_.end(), | 139 std::set_intersection(workers_.begin(), workers_.end(), |
| 140 session.workers_.begin(), session.workers_.end(), | 140 session.workers_.begin(), session.workers_.end(), |
| 141 std::back_inserter(temp)); | 141 std::back_inserter(temp)); |
| 142 workers_.swap(temp); | 142 workers_.swap(temp); |
| 143 | 143 |
| 144 // Now update enabled groups. | 144 // Now update enabled groups. |
| 145 enabled_groups_ = ComputeEnabledGroups(routing_info_, workers_); | 145 enabled_groups_ = ComputeEnabledGroups(routing_info_, workers_); |
| 146 } | 146 } |
| 147 | 147 |
| 148 void SyncSession::PrepareForAnotherSyncCycle() { | 148 void SyncSession::PrepareForAnotherSyncCycle() { |
| 149 finished_ = false; | 149 finished_ = false; |
| 150 source_.updates_source = | 150 source_.updates_source = |
| 151 sync_pb::GetUpdatesCallerInfo::SYNC_CYCLE_CONTINUATION; | 151 sync_pb::GetUpdatesCallerInfo::SYNC_CYCLE_CONTINUATION; |
| 152 status_controller_.reset(new StatusController(routing_info_)); | 152 status_controller_.reset(new StatusController(routing_info_)); |
| 153 } | 153 } |
| 154 | 154 |
| 155 SyncSessionSnapshot SyncSession::TakeSnapshot() const { | 155 SyncSessionSnapshot SyncSession::TakeSnapshot() const { |
| 156 syncable::Directory* dir = context_->directory(); | 156 syncable::Directory* dir = context_->directory(); |
| 157 | 157 |
| 158 bool is_share_useable = true; | 158 bool is_share_useable = true; |
| 159 ModelTypeSet initial_sync_ended; | 159 ModelTypeSet initial_sync_ended; |
| 160 ModelTypePayloadMap download_progress_markers; | 160 ModelTypeStateMap download_progress_markers; |
| 161 for (int i = FIRST_REAL_MODEL_TYPE; i < MODEL_TYPE_COUNT; ++i) { | 161 for (int i = FIRST_REAL_MODEL_TYPE; i < MODEL_TYPE_COUNT; ++i) { |
| 162 ModelType type(ModelTypeFromInt(i)); | 162 ModelType type(ModelTypeFromInt(i)); |
| 163 if (routing_info_.count(type) != 0) { | 163 if (routing_info_.count(type) != 0) { |
| 164 if (dir->initial_sync_ended_for_type(type)) | 164 if (dir->initial_sync_ended_for_type(type)) |
| 165 initial_sync_ended.Put(type); | 165 initial_sync_ended.Put(type); |
| 166 else | 166 else |
| 167 is_share_useable = false; | 167 is_share_useable = false; |
| 168 } | 168 } |
| 169 dir->GetDownloadProgressAsString(type, &download_progress_markers[type]); | 169 // TODO(dcheng): Is this correct? I'm guessing GetDownloadProgressAsString() |
| 170 // shouldn't care about the ack handle... |
| 171 dir->GetDownloadProgressAsString(type, |
| 172 &download_progress_markers[type].payload); |
| 170 } | 173 } |
| 171 | 174 |
| 172 return SyncSessionSnapshot( | 175 return SyncSessionSnapshot( |
| 173 status_controller_->model_neutral_state(), | 176 status_controller_->model_neutral_state(), |
| 174 is_share_useable, | 177 is_share_useable, |
| 175 initial_sync_ended, | 178 initial_sync_ended, |
| 176 download_progress_markers, | 179 download_progress_markers, |
| 177 HasMoreToSync(), | 180 HasMoreToSync(), |
| 178 delegate_->IsSyncingCurrentlySilenced(), | 181 delegate_->IsSyncingCurrentlySilenced(), |
| 179 status_controller_->TotalNumEncryptionConflictingItems(), | 182 status_controller_->TotalNumEncryptionConflictingItems(), |
| (...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 264 // with the server. Therefore, we verify no errors and at least one SYNCER_OK. | 267 // with the server. Therefore, we verify no errors and at least one SYNCER_OK. |
| 265 return reached_server && !HadErrors(state); | 268 return reached_server && !HadErrors(state); |
| 266 } | 269 } |
| 267 | 270 |
| 268 void SyncSession::SetFinished() { | 271 void SyncSession::SetFinished() { |
| 269 finished_ = true; | 272 finished_ = true; |
| 270 } | 273 } |
| 271 | 274 |
| 272 } // namespace sessions | 275 } // namespace sessions |
| 273 } // namespace syncer | 276 } // namespace syncer |
| OLD | NEW |