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

Side by Side 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 unified diff | Download patch
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 "chrome/browser/extensions/api/storage/setting_sync_data.h" 5 #include "chrome/browser/extensions/api/storage/setting_sync_data.h"
6 6
7 #include "base/json/json_reader.h" 7 #include "base/json/json_reader.h"
8 #include "base/json/json_writer.h" 8 #include "base/json/json_writer.h"
9 #include "sync/api/sync_data.h" 9 #include "sync/api/sync_data.h"
10 #include "sync/protocol/app_setting_specifics.pb.h" 10 #include "sync/protocol/app_setting_specifics.pb.h"
11 #include "sync/protocol/extension_setting_specifics.pb.h" 11 #include "sync/protocol/extension_setting_specifics.pb.h"
12 #include "sync/protocol/sync.pb.h" 12 #include "sync/protocol/sync.pb.h"
13 13
14 namespace extensions { 14 namespace extensions {
15 15
16 SettingSyncData::SettingSyncData( 16 SettingSyncData::SettingSyncData(const syncer::SyncChange& sync_change)
17 const syncer::SyncChange& sync_change) { 17 : change_type_(sync_change.change_type()) {
18 Init(sync_change.change_type(), sync_change.sync_data()); 18 ExtractSyncData(sync_change.sync_data());
19 } 19 }
20 20
21 SettingSyncData::SettingSyncData( 21 SettingSyncData::SettingSyncData(const syncer::SyncData& sync_data)
22 const syncer::SyncData& sync_data) { 22 : change_type_(syncer::SyncChange::ACTION_INVALID) {
23 Init(syncer::SyncChange::ACTION_INVALID, sync_data); 23 ExtractSyncData(sync_data);
24 } 24 }
25 25
26 void SettingSyncData::Init( 26 SettingSyncData::SettingSyncData(syncer::SyncChange::SyncChangeType change_type,
27 syncer::SyncChange::SyncChangeType change_type, 27 const std::string& extension_id,
28 const syncer::SyncData& sync_data) { 28 const std::string& key,
29 DCHECK(!internal_.get()); 29 scoped_ptr<base::Value> value)
30 sync_pb::EntitySpecifics specifics = sync_data.GetSpecifics();
31 // The data must only be either extension or app specfics.
32 DCHECK_NE(specifics.has_extension_setting(),
33 specifics.has_app_setting());
34 if (specifics.has_extension_setting()) {
35 InitFromExtensionSettingSpecifics(
36 change_type,
37 specifics.extension_setting());
38 } else if (specifics.has_app_setting()) {
39 InitFromExtensionSettingSpecifics(
40 change_type,
41 specifics.app_setting().extension_setting());
42 }
43 }
44
45 void SettingSyncData::InitFromExtensionSettingSpecifics(
46 syncer::SyncChange::SyncChangeType change_type,
47 const sync_pb::ExtensionSettingSpecifics& specifics) {
48 DCHECK(!internal_.get());
49 scoped_ptr<base::Value> value(
50 base::JSONReader::Read(specifics.value()));
51 if (!value.get()) {
52 LOG(WARNING) << "Specifics for " << specifics.extension_id() << "/" <<
53 specifics.key() << " had bad JSON for value: " << specifics.value();
54 value.reset(new base::DictionaryValue());
55 }
56 internal_ = new Internal(
57 change_type,
58 specifics.extension_id(),
59 specifics.key(),
60 value.Pass());
61 }
62
63 SettingSyncData::SettingSyncData(
64 syncer::SyncChange::SyncChangeType change_type,
65 const std::string& extension_id,
66 const std::string& key,
67 scoped_ptr<base::Value> value)
68 : internal_(new Internal(change_type, extension_id, key, value.Pass())) {}
69
70 SettingSyncData::~SettingSyncData() {}
71
72 syncer::SyncChange::SyncChangeType SettingSyncData::change_type() const {
73 return internal_->change_type_;
74 }
75
76 const std::string& SettingSyncData::extension_id() const {
77 return internal_->extension_id_;
78 }
79
80 const std::string& SettingSyncData::key() const {
81 return internal_->key_;
82 }
83
84 const base::Value& SettingSyncData::value() const {
85 return *internal_->value_;
86 }
87
88 SettingSyncData::Internal::Internal(
89 syncer::SyncChange::SyncChangeType change_type,
90 const std::string& extension_id,
91 const std::string& key,
92 scoped_ptr<base::Value> value)
93 : change_type_(change_type), 30 : change_type_(change_type),
94 extension_id_(extension_id), 31 extension_id_(extension_id),
95 key_(key), 32 key_(key),
96 value_(value.Pass()) { 33 value_(value.Pass()) {
97 DCHECK(value_.get());
98 } 34 }
99 35
100 SettingSyncData::Internal::~Internal() {} 36 SettingSyncData::~SettingSyncData() {}
37
38 scoped_ptr<base::Value> SettingSyncData::PassValue() {
39 DCHECK(value_) << "value has already been Pass()ed";
40 return value_.Pass();
41 }
42
43 void SettingSyncData::ExtractSyncData(const syncer::SyncData& sync_data) {
44 sync_pb::EntitySpecifics specifics = sync_data.GetSpecifics();
45 // The specifics are exclusively either extension or app settings.
46 DCHECK_NE(specifics.has_extension_setting(), specifics.has_app_setting());
47 const sync_pb::ExtensionSettingSpecifics& extension_specifics =
48 specifics.has_extension_setting()
49 ? specifics.extension_setting()
50 : specifics.app_setting().extension_setting();
51
52 extension_id_ = extension_specifics.extension_id();
53 key_ = extension_specifics.key();
54 value_.reset(base::JSONReader::Read(extension_specifics.value()));
55
56 if (!value_) {
57 LOG(WARNING) << "Specifics for " << extension_id_ << "/" << key_
58 << " had bad JSON for value: " << extension_specifics.value();
59 value_.reset(new base::DictionaryValue());
60 }
61 }
101 62
102 } // namespace extensions 63 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698