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

Unified Diff: components/sync/model/model_type_service.cc

Issue 2406163006: [Sync] Services can now always assume processor exists. (Closed)
Patch Set: Updates for Max. Created 4 years, 2 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « components/sync/model/model_type_service.h ('k') | components/sync/model/model_type_service_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/sync/model/model_type_service.cc
diff --git a/components/sync/model/model_type_service.cc b/components/sync/model/model_type_service.cc
index 17905ccbf8e3963666d9a669081da9f8ba22a126..59de0c9b9e80e82593d80a0add911af6bb079ad0 100644
--- a/components/sync/model/model_type_service.cc
+++ b/components/sync/model/model_type_service.cc
@@ -6,19 +6,23 @@
#include <utility>
+#include "base/memory/ptr_util.h"
+#include "components/sync/model/metadata_batch.h"
+
namespace syncer {
ModelTypeService::ModelTypeService(
const ChangeProcessorFactory& change_processor_factory,
ModelType type)
- : change_processor_factory_(change_processor_factory), type_(type) {}
+ : type_(type),
+ change_processor_factory_(change_processor_factory),
+ change_processor_(change_processor_factory_.Run(type_, this)) {}
ModelTypeService::~ModelTypeService() {}
ConflictResolution ModelTypeService::ResolveConflict(
const EntityData& local_data,
const EntityData& remote_data) const {
- // TODO(maxbogue): Add tests once a file exists for them (crbug.com/543407).
if (remote_data.is_deleted()) {
DCHECK(!local_data.is_deleted());
return ConflictResolution::UseLocal();
@@ -29,30 +33,23 @@ ConflictResolution ModelTypeService::ResolveConflict(
void ModelTypeService::OnSyncStarting(
std::unique_ptr<DataTypeErrorHandler> error_handler,
const ModelTypeChangeProcessor::StartCallback& start_callback) {
- CreateChangeProcessor();
change_processor_->OnSyncStarting(std::move(error_handler), start_callback);
}
void ModelTypeService::DisableSync() {
DCHECK(change_processor_);
change_processor_->DisableSync();
- change_processor_.reset();
-}
-
-void ModelTypeService::CreateChangeProcessor() {
- if (!change_processor_) {
- change_processor_ = change_processor_factory_.Run(type_, this);
- DCHECK(change_processor_);
- OnChangeProcessorSet();
- }
+ change_processor_ = change_processor_factory_.Run(type_, this);
+ // DisableSync() should delete all metadata, so it'll be safe to tell the new
+ // processor that there is no metadata. DisableSync() should never be called
+ // while the models are loading, aka before the service has finished loading
+ // the initial metadata.
+ change_processor_->OnMetadataLoaded(SyncError(),
+ base::MakeUnique<MetadataBatch>());
}
ModelTypeChangeProcessor* ModelTypeService::change_processor() const {
return change_processor_.get();
}
-void ModelTypeService::clear_change_processor() {
- change_processor_.reset();
-}
-
} // namespace syncer
« no previous file with comments | « components/sync/model/model_type_service.h ('k') | components/sync/model/model_type_service_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698