| 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
|
|
|