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

Unified Diff: chrome/browser/extensions/api/storage/setting_sync_data.cc

Issue 1141963002: Remove a bunch of DeepCopy() calls in the chrome.storage API. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: comments Created 5 years, 7 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
Index: chrome/browser/extensions/api/storage/setting_sync_data.cc
diff --git a/chrome/browser/extensions/api/storage/setting_sync_data.cc b/chrome/browser/extensions/api/storage/setting_sync_data.cc
index 212f5c7abb1bd78d97cac81c2410b4d69c88fab9..ff65daf1a90d906fa143c33ca296702f85b80dfb 100644
--- a/chrome/browser/extensions/api/storage/setting_sync_data.cc
+++ b/chrome/browser/extensions/api/storage/setting_sync_data.cc
@@ -13,90 +13,51 @@
namespace extensions {
-SettingSyncData::SettingSyncData(
- const syncer::SyncChange& sync_change) {
- Init(sync_change.change_type(), sync_change.sync_data());
+SettingSyncData::SettingSyncData(const syncer::SyncChange& sync_change)
+ : change_type_(sync_change.change_type()) {
+ ExtractSyncData(sync_change.sync_data());
}
-SettingSyncData::SettingSyncData(
- const syncer::SyncData& sync_data) {
- Init(syncer::SyncChange::ACTION_INVALID, sync_data);
+SettingSyncData::SettingSyncData(const syncer::SyncData& sync_data)
+ : change_type_(syncer::SyncChange::ACTION_INVALID) {
+ ExtractSyncData(sync_data);
}
-void SettingSyncData::Init(
- syncer::SyncChange::SyncChangeType change_type,
- const syncer::SyncData& sync_data) {
- DCHECK(!internal_.get());
- sync_pb::EntitySpecifics specifics = sync_data.GetSpecifics();
- // The data must only be either extension or app specfics.
- DCHECK_NE(specifics.has_extension_setting(),
- specifics.has_app_setting());
- if (specifics.has_extension_setting()) {
- InitFromExtensionSettingSpecifics(
- change_type,
- specifics.extension_setting());
- } else if (specifics.has_app_setting()) {
- InitFromExtensionSettingSpecifics(
- change_type,
- specifics.app_setting().extension_setting());
- }
-}
-
-void SettingSyncData::InitFromExtensionSettingSpecifics(
- syncer::SyncChange::SyncChangeType change_type,
- const sync_pb::ExtensionSettingSpecifics& specifics) {
- DCHECK(!internal_.get());
- scoped_ptr<base::Value> value(
- base::JSONReader::Read(specifics.value()));
- if (!value.get()) {
- LOG(WARNING) << "Specifics for " << specifics.extension_id() << "/" <<
- specifics.key() << " had bad JSON for value: " << specifics.value();
- value.reset(new base::DictionaryValue());
- }
- internal_ = new Internal(
- change_type,
- specifics.extension_id(),
- specifics.key(),
- value.Pass());
+SettingSyncData::SettingSyncData(syncer::SyncChange::SyncChangeType change_type,
+ const std::string& extension_id,
+ const std::string& key,
+ scoped_ptr<base::Value> value)
+ : change_type_(change_type),
+ extension_id_(extension_id),
+ key_(key),
+ value_(value.Pass()) {
}
-SettingSyncData::SettingSyncData(
- syncer::SyncChange::SyncChangeType change_type,
- const std::string& extension_id,
- const std::string& key,
- scoped_ptr<base::Value> value)
- : internal_(new Internal(change_type, extension_id, key, value.Pass())) {}
-
SettingSyncData::~SettingSyncData() {}
-syncer::SyncChange::SyncChangeType SettingSyncData::change_type() const {
- return internal_->change_type_;
-}
-
-const std::string& SettingSyncData::extension_id() const {
- return internal_->extension_id_;
+scoped_ptr<base::Value> SettingSyncData::PassValue() {
+ DCHECK(value_) << "value has already been Pass()ed";
+ return value_.Pass();
}
-const std::string& SettingSyncData::key() const {
- return internal_->key_;
-}
-
-const base::Value& SettingSyncData::value() const {
- return *internal_->value_;
-}
-
-SettingSyncData::Internal::Internal(
- syncer::SyncChange::SyncChangeType change_type,
- const std::string& extension_id,
- const std::string& key,
- scoped_ptr<base::Value> value)
- : change_type_(change_type),
- extension_id_(extension_id),
- key_(key),
- value_(value.Pass()) {
- DCHECK(value_.get());
+void SettingSyncData::ExtractSyncData(const syncer::SyncData& sync_data) {
+ sync_pb::EntitySpecifics specifics = sync_data.GetSpecifics();
+ // The specifics are exclusively either extension or app settings.
+ DCHECK_NE(specifics.has_extension_setting(), specifics.has_app_setting());
+ const sync_pb::ExtensionSettingSpecifics& extension_specifics =
+ specifics.has_extension_setting()
+ ? specifics.extension_setting()
+ : specifics.app_setting().extension_setting();
+
+ extension_id_ = extension_specifics.extension_id();
+ key_ = extension_specifics.key();
+ value_.reset(base::JSONReader::Read(extension_specifics.value()));
+
+ if (!value_) {
+ LOG(WARNING) << "Specifics for " << extension_id_ << "/" << key_
+ << " had bad JSON for value: " << extension_specifics.value();
+ value_.reset(new base::DictionaryValue());
+ }
}
-SettingSyncData::Internal::~Internal() {}
-
} // namespace extensions

Powered by Google App Engine
This is Rietveld 408576698